Redis(6)Clients - Scala Clients

本文介绍如何使用Scala和Jedis客户端连接Redis,并设置集群模式。包括Redis服务端的安装配置、Scala客户端的基本使用及集群模式下的操作示例。

Redis(6)Clients - Scala Clients

Upgrade the Redis to latest
>wget http://download.redis.io/releases/redis-2.8.7.tar.gz
Unzip it 
>cd redis-2.8.7
>make
>mkdir /Users/carl/tool/redis-2.8.7
>cd src/
>cp redis-server /Users/carl/tool/redis-2.8.7/
>cp redis-benchmark /Users/carl/tool/redis-2.8.7/
>cp redis-cli /Users/carl/tool/redis-2.8.7/

>cd ..
>cp redis.conf /Users/carl/tool/redis-2.8.7/
>pwd
/Users/carl/tool/redis-2.8.7


5. Scala Client

Here is the official website of jedis https://github.com/xetorthio/jedis

5.1 Simple Usage
"redis.clients" % "jedis" % "2.4.1"

package com.sillycat.easynosqlscala.app

import redis.clients.jedis.Jedis

object TestRedisDBConnectionApp extends App{
  val jedis = new Jedis("localhost")
  jedis.set("name","sillycat")
  println(jedis.get("name"))

}

5.2 Working with Cluster

There should be not only the redis-server file, but also this file under the src directory, 
>cp redis-sentinel /Users/carl/tool/redis-2.8.7/

Here is the configuration file
>cp /Users/carl/data/redis-2.8.7/sentinel.conf /opt/redis/

Prepare all these configuration files.
>vi redis-0/redis.conf
port 6379 
>vi redis-1/redis.conf
port 6479
slaveof 127.0.0.1 6379

>vi sentinel-0/sentinel.conf
port 26379

>vi sentinel-1/sentinel.conf 
port 26479

Start Commands
>./redis-server redis-0/redis.conf
>./redis-server redis-1/redis.conf
>./redis-sentinel sentinel-0/sentinel.conf
>./redis-sentinel sentinel-1/sentinel.conf 

Then I have 1 master of Redis instance on 6379, 1 slave of Redis instance on 6479.
1 Sentinel on 26379, 1 sentinel on 26479.

Information
>./redis-cli -h 127.0.0.1 -p 26379 info Sentinel 
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
master0:name=mymaster,status=ok,address=127.0.0.1:6479,slaves=1,sentinels=2

>./redis-cli -h 127.0.0.1 -p 6479
redis>info

This seems to be only the master-slave mode.

Try to Connect the server with this Jedis Client
package com.sillycat.easynosqlscala.app

import redis.clients.jedis.{JedisCluster, HostAndPort, Jedis}
import java.util.HashSet

object TestRedisDBConnectionApp extends App{
  val jedis = new Jedis("localhost")
  jedis.set("name","sillycat")
  println(jedis.get("name"))

  val jedisClusterNodes = new HashSet[HostAndPort]
  jedisClusterNodes.add(new HostAndPort("127.0.0.1", 6379))
  jedisClusterNodes.add(new HostAndPort("127.0.0.1", 6479))
  val jc = new JedisCluster(jedisClusterNodes)
  jc.set("age","32")
  println("name = " + jedis.get("name") + " age = " + jc.get("age"))

}


Tips:
Error Message:
sbt.ResolveException: download failed: javax.jms#jms;1.1!jms.jar

Solution:
add this to the resolvers
"MIT repo"           at "http://simile.mit.edu/maven/"

Error Message:
Exception in thread "main" redis.clients.jedis.exceptions.JedisDataException: ERR unknown command 'CLUSTER'
     at redis.clients.jedis.Protocol.processError(Protocol.java:100)

Solution:
It seems to me that I am not running Redis under cluster mode.


References:
https://github.com/debasishg/scala-redis
https://github.com/top10/scala-redis-client
https://github.com/alphazero/jredis
https://github.com/xetorthio/jedis

Redis 1~5
http://sillycat.iteye.com/blog/1549504   installation
http://sillycat.iteye.com/blog/1553507   Different Types
http://sillycat.iteye.com/blog/1553508   Different Types
http://sillycat.iteye.com/blog/1553509   Example Operations
http://sillycat.iteye.com/blog/2028180   HA and Setup on MAC


<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.sxemc</groupId> <artifactId>demo11</artifactId> <version>1.0-SNAPSHOT</version> <properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <!-- 统一版本控制 --> <flink.version>1.14.0</flink.version> <scala.binary.version>2.12</scala.binary.version> </properties> <dependencies> <!-- Flink Scala API --> <dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-scala_${scala.binary.version}</artifactId> <version>${flink.version}</version> </dependency> <!-- Flink Streaming --> <dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-streaming-scala_${scala.binary.version}</artifactId> <version>${flink.version}</version> </dependency> <!-- Flink Clients --> <dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-clients_${scala.binary.version}</artifactId> <version>${flink.version}</version> </dependency> <!-- Hadoop Client --> <dependency> <groupId>org.apache.hadoop</groupId> <artifactId>hadoop-client</artifactId> <version>3.3.1</version> </dependency> <!-- ✅ 修复点1:统一为 Scala 2.12 + Flink 1.14.0 的 Kafka Connector --> <dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-connector-kafka_${scala.binary.version}</artifactId> <version>${flink.version}</version> </dependency> <dependency> <groupId>org.apache.bahir</groupId> <artifactId>flink-connector-redis_2.11</artifactId> <version>1.0</version> </dependency> <!-- ✅ 修复点2:添加 SimpleStringSchema 所需依赖 --> <dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-json</artifactId> <version>${flink.version}</version> </dependency> <!-- ✅ 可选:解决 SLF4J 警告 --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-simple</artifactId> <version>1.7.36</version> </dependency> </dependencies> <build> <plugins> <!-- 指定编译 JDK 版本 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.1</version> <configuration> <source>8</source> <target>8</target> <encoding>UTF-8</encoding> </configuration> </plugin> <!-- Scala 编译插件 --> <plugin> <groupId>net.alchim31.maven</groupId> <artifactId>scala-maven-plugin</artifactId> <version>4.5.6</version> <executions> <execution> <goals> <goal>compile</goal> <goal>testCompile</goal> </goals> </execution> </executions> </plugin> <!-- Shade 插件打包成 fat jar --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>3.4.1</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <filters> <filter> <artifact>*:*</artifact> <excludes> <exclude>META-INF/*.SF</exclude> <exclude>META-INF/*.DSA</exclude> <exclude>META-INF/*.RSA</exclude> </excludes> </filter> </filters> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <!-- ✅ 修复点3:请替换为你主类的全路径 --> <mainClass>KafkaForwardJob</mainClass> </transformer> </transformers> <!-- 避免 Kafka 类冲突 --> <relocations> <relocation> <pattern>org.apache.kafka</pattern> <shadedPattern>shaded.org.apache.kafka</shadedPattern> </relocation> </relocations> </configuration> </execution> </executions> </plugin> </plugins> </build> </project> 那不对
最新发布
09-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值