docker实战安装mysql,mongodb,redis

安装mysql

今天试试mysql实战安装myql
先pull镜像

docker pull mysql:5.6

接着启动mysql镜像

docker run -p 12345:3306 --name mysql56 \
-v  /home/zack/dockerwork/mysql/conf:/etc/mysql/conf.d \
-v  /home/zack/dockerwork/mysql/logs:/logs \
-v  /home/zack/dockerwork/mysql/data:/var/lib/mysql \
-e  MYSQL_ROOT_PASSWORD=123456  \
-d  mysql:5.6

我们查看下docker ps 列出所有docker进程 

然后我们进入docker里

docker exec -it 615164d51197 /bin/bash

进入后我们使用myql登录 

mysql -uroot -p

输入密码后进入mysql。之后就可以建立数据库和表了。 

启动mongo容器

首先先下载mongo的安装包,然后解压放在自己设定的目录下

FROM ansible/centos7-ansible:latest
RUN mkdir -p /data/mongodb/log/
RUN mkdir -p /data/mongodb/bin
RUN mkdir -p /data/mongodb/data
#RUN yum install libssl1.0.0 libssl-dev
ENV PATH /data/mongodb/bin:$PATH
ADD mongodb-linux-x86_64-rhel70-4.2.8 /data/mongodb
WORKDIR /data/mongodb/
EXPOSE 60000
#VOLUME ["/data/env/mongo/data/:/data/mongodb/data","/data/env/mongo/log/:/data/mongodb/log/"]
CMD ["/data/mongodb/bin/mongod","-f", "/data/mongodb/mongodb.conf"]

根据Dockerfile生成镜像

docker build -f ./Dockerfile -t mymongo .

启动docker

docker run  -p 54321:60000 --name submitmg -v /home/zack/dockerwork/mongodb_/data:/data/mongodb/data  -v /home/zack/dockerwork/mongodb_/log:/data/mongodb/log/  --privileged=true  -d  mymongo

进入docker容器

docker exec -it cdebf8e13939 /bin/bash

登录数据库 

./mongo --port 60000

创建数据库 submit 

use submit

创建数据库表 

db.createCollection("log_info")

文档结构如下 

{
    "compareid":"12345",
    "ic":"23333HC",
    "phone":"18301152001",
    "url":"www.singlepo.com",
    "dir":0,
    "imageurl":"www.singlepo.com/wangqiang.jpg"
}

创建索引 

db.log_info.createIndex({"ic":1,"compareid":-1})

插入数据测试 

db.log_info.insert({
    "compareid":"12345",
    "ic":"23333HC",
    "phone":"18301152001",
    "url":"www.singlepo.com",
    "dir":0,
    "imageurl":"www.singlepo.com/wangqiang.jpg"
})

查询刚才插入的数据 

db.log_info.find()

启动redis容器 

1 拉取镜像

docker pull redis:3.2

2 用镜像启动容器 

docker run -p 6679:6379 -v /home/zack/dockerwork/redis/data:/data 
-v /home/zack/dockerwork/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf  
-d redis:3.2 redis-server  /usr/local/etc/redis/redis.conf --appendonly yes

3 配置redis
在/home/zack/dockerwork/redis/conf/redis.conf下创建redis.conf文件

port 6379

tcp-backlog 511

timeout 0

tcp-keepalive 0

loglevel notice

logfile ""

databases 16

save 900 1
save 300 10
save 60 10000

stop-writes-on-bgsave-error yes

rdbchecksum yes

dbfilename dump.rdb

dir ./

slave-serve-stale-data yes

slave-read-only yes

repl-diskless-sync no

repl-diskless-sync-delay 5

repl-disable-tcp-nodelay no

slave-priority 100

maxheap 51200000

heapdir ./

appendonly no

appendfilename "appendonly.aof"

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

aof-load-truncated yes

lua-time-limit 5000

slowlog-log-slower-than 10000

slowlog-max-len 128

latency-monitor-threshold 0

notify-keyspace-events ""

hash-max-ziplist-entries 512
hash-max-ziplist-value 64

list-max-ziplist-entries 512
list-max-ziplist-value 64

set-max-intset-entries 512

zset-max-ziplist-entries 128
zset-max-ziplist-value 64

hll-sparse-max-bytes 3000

activerehashing yes

client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes

4 启动客户端 

docker exec -it 139abd0bd512 redis-cli
进入命令模式后就可以set key value测试了。退出容器可以在redis/data路径里看到appendonly.aof文件里有命令

感谢关注公众号

今天的笔记就这些吧,感谢关注公众号
docker实战安装mysql,mongodb,redis_第1张图片

你可能感兴趣的:(docker)