Docker容器之间的连接可以带来不少方便,下面记录下如何在自己容器内通过环境变量连接与之连接的Redis容器的方法。
先起一个Redis的Docker容器,命名为 redis,再起一个自己的Docker容器,使用"--link redis:redis"方式与redis容器连接。
在自己的容器内部,会有对应的环境变量,其中这里用的就是 REDIS_PORT = tcp://172.17.0.89:6379。
将其分拆为 tcp 和 172.17.0.89:6379,作为参数传入redigo的Dial函数即可,如此可不必显式的写IP和端口地址。
顺便说一句,redigo是Go语言的Redis客户端实现。
参考代码如下:
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
"os"
"strings"
"time"
)
func testRedis() bool {
// e.g. REDIS_PORT = tcp://172.17.0.89:6379
fmt.Println("REDIS_PORT", os.Getenv("REDIS_PORT"))
addr := strings.Split(os.Getenv("REDIS_PORT"), "://")
conn, err := redis.DialTimeout(addr[0], addr[1], 0, 1*time.Second, 1*time.Second)
if err != nil {
fmt.Println(err)
return false
}
defer conn.Close()
size, err := conn.Do("DBSIZE")
if err != nil {
fmt.Println(err)
return false
}
fmt.Printf("DB size is %d \n", size)
_, err = conn.Do("SET", "user:user0", 123)
_, err = conn.Do("SET", "user:user1", 456)
_, err = conn.Do("APPEND", "user:user0", 87)
user0, err := redis.Int(conn.Do("GET", "user:user0"))
user1, err := redis.Int(conn.Do("GET", "user:user1"))
fmt.Printf("user0 is %d , user1 is %d \n", user0, user1)
return true
}
func main() {
fmt.Println(time.Now(), "[Redis test start]")
if testRedis() {
fmt.Println("[Redis test ok]")
} else {
fmt.Println("[Redis test failed]")
}
}
如果连接成功,结果如下:
2015-03-12 12:16:44.796537101 +0000 UTC [Redis test start]
REDIS_PORT tcp://172.17.0.89:6379
DB size is 2
user0 is 12387 , user1 is 456
[Redis test ok]
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com