搭建Docker应用栈
1、获取应用栈各个节点所需镜像
#docker pull ubuntu
#docker pull django
#docker pull haproxy
#docker pull redis
#docler images
2、创建并启动各个栈容器
1)启动redis-master容器
#docker run -it --name redis-master redis /bin/bash
注意:可以通过Ctrl+P+Q 退出容器(以下同)
2)启动redis-slave1容器,并连接至redis-master容器
#docker run -it --name redis-slave1 --link redis-master:master redis /bin/bash
3)启动redis-slave2容器,并连接至redis-master容器
#docker run -it --name redis-slave2 --link redis-master:master redis /bin/bash
4)启动Django容器集群,并连接至redis-master容器
#docker run -it --name APP1 --link redis-master:db -v ~/Projects/Django/App1:/usr/src/app django /bin/bash
#docker run -it --name APP2 --link redis-master:db -v ~/Projects/Django/App2:/usr/src/app django /bin/bash
5)启动HAProxy容器,并连接至APP1和APP2
#docker run -it --name HAProxy --link APP1:APP1 --link APP2:APP2 -p 6301:6301 -v ~/Projects/HAProxy:/tmp haproxy /bin/bas
容器配置
1、redis-master主数据库容器配置
#docker attach redis-master
#apt-get update
#apt-get install vim
#cd /usr/local/bin
#touch redis.conf
#redis-server redis.conf
#cat redis.log
redis.conf中配置如下:
1)bind 0.0.0.02)daemonize yes
3)pidfile /var/run/redis.pid
4)logfile "/usr/local/bin/redis.log"
2、redis-slave1/slave2从数据库容器配置
#docker attach redis-slave1
#apt-get update
#apt-get install vim
#cd /usr/local/bin
#touch redis.conf
#redis-server redis.conf
#cat redis.log
redis.conf中配置如下:
1)daemonize yes
2)pidfile /var/run/redis.pid
3)logfile "/usr/local/bin/redis.log"
4) slaveof master 6379
常见问题:
1、unable to resolve host XXX修改/etc/hosts文件,添加127.0.1.1 hostname,hostname 为主机名,查看文件:/etc/hostname 获得。
2、Bind address already in use
1)ps aux | grep redis
如:MyUser 8821 0.0 0.0 2459704 596 ?? S 4:54PM 0:03.40 redis-server *:6379
2)kill -9 8821
3、在redis.conf中添加日志目录
logfile "/usr/redis/log/redis.log"#日志保存路径