您的位置:首页 > 运维架构 > Docker

四、Docker安装使用 容器

2017-11-03 02:20 423 查看

容器管理

plus:

docker本身是一个C/S架构

客户端用于我们敲命令啊之类的

服务端提供了一些api 等 可以通过ps -ef | docker 看到服务主进程

如果要拉你在公有仓库里面自己仓库里的东西可以

docker login daocloud.io

username:

password:

基本操作

容器相关操作

docker create # 创建一个容器但是不启动它 docker run # 创建并启动一个容器

docker stop # 停止容器运行,发送信号SIGTERM docker kill #强制终止一个容器

docker start # 启动一个停止状态的容器

docker restart # 重启一个容器

docker rmi # 删除一个容器

docker rm $(docker ps -a -q)

docker kill # 发送信号给容器,默认SIGKILL docker attach # 连接(进入)到一个正在运行的容器 docker wait # 阻塞到一个容器,直到容器停止运行 docker –restart=always 容器

docker ps # 显示状态为运行(Up)的容器

docker ps -a # 显示所有容器,包括运行中(Up)的和退出的(Exited)

docker inspect # 深入容器内部获取容器所有信息

docker logs -f # 查看容器的日志(stdout/stderr)(-f 用于实时输出)

docker events # 得到docker服务器的实时的事件

docker port # 显示容器的端口映射

docker top # 显示容器的进程信息

docker diff # 显示容器文件系统的前后变化

测试

创建一个容器并启动容器

比如:

docker run -it –name=inspect_shell centos:7 /bin/bash

创建一个名字为inspect_shell的容器,并启动了该容器(交互式容器)

docker run –name daemon_hello -d centos:7 /bin/bash -c ”

while true;do echo hello word;sleep 1;done”

创建一个名字为daemon_hello的容器,并启动了该容器(后台型容器)

数据持久化

两种方式实现:

1.宿主机挂载点

-v

2.公用容器

–volumes-from

容器销毁不会影响到数据卷

在集群服务中可以通过实现宿主机存储集群来实现集群数据持久化

搭建LNMP网站

1.启动一个数据库

docker search 去找一个你需要的版本

docker pull mysql:5.6

你可以先获取镜像帮助来更好的使用镜像

docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=xy123456 --name xy_mysql mysql:5.6
映射到主机3307端口  创建一个密码为xy123456的数据库 容器名字为xy_mysql 镜像版本mysql5.6


同时 我们可以直接在真机上传入变量到容器 获取容器信息

docker exec  xy_mysql  sh -c 'mysql -uroot -p"$MYSQL_ROOT_PASSWORD" -e "show databases" '


plus:这里为我们提供了一个一次性构建的思路



设置好mysql的密码是什么?创建的数据库是什么?要不要建立用户?建立用户要不要授权?

(这里可以同构shell脚本实现 同时也有更简单的方式 我在后面的博客中会记录 即通过导入sql表同时修改初始化配置文件来实现)

容器中的数据文件目录是什么? 如何挂载来实现存储数据的持久化?

2.创建一个php解析环境

docker run -d -  v   /var/nginx/www/html:/var/www/html -p 9000:9000 --link xy_mysql:mysql --name xy_phpfpm php:7.0-fpm


参数说明

-d 让容器在后台运行

-p 添加主机到容器的端口映射

-v 添加目录映射,即主机上的/var/nginx/www/html和容器中/var/www/html目录是同步的

–name 容器的名字

–link 与另外一个容器建立起联系,这样我们就可以在当前容器中去使用另一个容器里的服务。

这里如果不指定–link参数其实也是可以得,因为容易本身也是有ip的且唯一,所以我们也可以直接利用ip去访问容器。

然后进入到我们的容器,然后我们在/var/www/html目录下新建一个index.php文件“
ac47
`

touch index.php

我们发现我们在容器里的/var/www/html目录中新建的文件也在主机的/var/nginx/www/html目录中,因为在创建容器的时候,我们已经把主机中的目录挂载到了容器中去了。

因为后面我要使用pdo模块进行测试,所以我需要自己安装pdo_mysql模块,在docker容器中可以这样来安装

docker-php-ext-install pdo_mysql


然后我们可以通过命令php -m查看我们的php的所有扩展模块,我们可以去看到我们刚刚安装的pdo_mysql扩展也在里面

3.搭建nginx

docker run -d -p 80:80 --name xy_nginx\
-v /var/nginx/www/html:/var/www/html\
--link xy_phpfpm:phpfpm --name xy_nginx nginx:1.10.3


-d 让容器在后台运行

-p 添加主机到容器的端口映射

-v 添加目录映射,这里最好nginx容器的根目录最好写成和php容器中根目录一样。但是不一点非要一模一样,如果不一样在配置nginx的时候需要注意

–name 容器的名字

–link 与另外一个容器建立起联系

然后进入nginx容器,修改nginx的配置文件让它支持php

docker exec -ti xy_nginx /bin/bash

location ~ \.php$ {
root           /var/www/html;
fastcgi_index  index.php;
fastcgi_pass   phpfpm:9000;//这里改成我们之前--link进来的容器,也可以直接用php容器的ip
fastcgi_param  SCRIPT_FILENAME $document_root$fastcdi_script_name;//如果你的根目录和php容器的根目录不一样,这里的$document_root需要换成你php下的根目录,不然php就找不到文件了
include        fastcgi_params;

}


测试一波

<?php
try {
$con = new PDO('mysql:host=mysql;dbname=test', 'xuye', 'xy123456');
$con->query('SET NAMES UTF8');
$res =  $con->query('select * from test');
while ($row = $res->fetch(PDO::FETCH_ASSOC)) {
echo "id:{$row['id']} name:{$row['name']}";
}
} catch (PDOException $e) {
echo '错误原因:'  . $e->getMessage();
}


当当当,看到正确的输出,就证明我们的配置成功了。一个最最最基本的环境就搭建好了。。

是不是参数很多很复杂????

没关系,后续我们可以通过docker-compose 来实现把这些参数写在yml文件里面 最后实现一次性构建 。

例如 :

构建node环境

node:

image: 7d10217beb82 镜像

container_name: node 容器名

ports: 映射端口

- “3014:3014”

- “3050:3050”

- “3051:3051”

- “8010:8010”

- “8024:8024”

- “3005:3005”

volumes:

- /data/www/htdocs:/data/www 数据持久化

extra_hosts: 附加进hosts文件

- “db.pro.com:1.1.1.1”

restart: always 自动重启

这里配置虚拟域名作为项目中mysql连接地址 可以很好的避免开发环境和测试环境每次要修改连接的问题

nginx:

image: 169bd14dcf7a

container_name: nginx

links:

- php

- node

- tomcat

ports:

- “80:80”

- “443:443”

- “8000:8000”

volumes:

- /data/www/htdocs:/data/www

- /data/logs/nginx:/var/log/nginx

- ./volumes/nginx/sites:/etc/nginx/sites-enabled

- ./volumes/nginx/includes:/etc/nginx/includes

extra_hosts:

- “db.pro.com:1.1.1.1”

restart: always

php:

image: 0b0b9f98dff2

container_name: php

ports:

- “9000:9000”

links:

- node

- mongodb

- redis

- mysql 这是需要能访问到的容器

volumes:

- /data/www/htdocs:/data/www

- /data/logs/php:/data/logs/php

extra_hosts:

- “db.pro.com:119.29.105.164”

restart: always

mysql:

image: 5a58d88e1b36

container_name: mysql

ports:

- “3306:3306”

volumes:

- /data/db/mysql:/data/db/mysql

- /data/logs/mysql:/data/logs/mysql

environment:

MYSQL_USER: “user_test”

MYSQL_PASSWORD: “N!F3ABaFui”

MYSQL_ROOT_PASSWORD: “T41Df!x2L4”

restart: always

redis:

image: c12f15d2ef75

container_name: redis

ports:

- “6379:6379”

volumes:

- /data/db/redis:/data/db/redis

- /data/logs/redis:/data/logs/redis

restart: always

memcached:

image: 1739564665db

container_name: memcached

ports:

- “11211:11211”

restart: always

mongodb:

image: 8e058d1bebf7

container_name: mongodb

ports:

- “27017:27017”

volumes:

- /data/db/mongodb:/data/db/mongodb

- /data/logs/mongodb:/data/logs/mongodb

environment:

AUTH: “yes”

JOURNALING: “yes”

MONGODB_DATABASE: “test”

MONGODB_USER: “test”

MONGODB_PASS: “541R4evB”

restart: always

最终就会一键构建起一套

以nginx作为web容器 能解析php项目 访问到node接口 后端有mysql mongo以及redis 并且数据能够持久化保存的一套web环境
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: