Docker入门
安装Docker
Docker可以运行在MAC、Windows、CentOS、UBUNTU等操作系统上,本课程基于CentOS 7 安装Docker
官网
docker架构
docker 常用命令
进程相关命令
启动docker服务:
systemctl start docker
停止docker服务:
systemctl stop docker
重启docker服务:
systemctl restart docker
查看docker服务状态:
systemctl status docker
设置开机启动docker服务:
systemctl enable docker
镜像相关命令
查看镜像: 查看本地所有的镜像
docker images
docker images –q # 查看所用镜像的id
搜索镜像:从网络中查找需要的镜像
docker search 镜像名称
docker search redis #查找redis镜像
拉取镜像:从Docker仓库下载镜像到本地,镜像名称格式为 名称:版本号,如果版本号不指定则是最新的版本 lastest。
如果不知道镜像版本,可以去docker hub 搜索对应镜像查看。
docker pull 镜像名称
docker pull redis #下载最新版本redis
docker pull redis:5.0 #下载5.0版本redis
删除镜像: 删除本地镜像
docker rmi 镜像id # 删除指定本地镜像
docker images -q #查看所有的镜像列表
docker rmi `docker images -q` # 删除所有本地镜像
容器相关命令
查看容器
docker ps # 查看正在运行的容器
docker ps –a # 查看所有容器
创建并启动容器
docker run 参数
docker run -it --name=c1 centos:7 /bin/bash #创建交互式容器 docker run -id --name=c2 centos:7 #创建守护式容器
注意:交互式容器,exit后容器自动关闭,守护式容器会在后台执行
进入容器
docker exec -it c2 /bin/bash #进入容器
停止容器
docker stop 容器名称
启动容器
docker start 容器名称
删除容器:如果容器是运行状态则删除失败,需要停止容器才能删除
docker rm 容器名称
查看容器信息
docker inspect 容器名称
容器的数据卷
配置数据卷
创建启动容器时,使用 –v 参数 设置数据卷
docker run ... –v 宿主机目录(文件):容器内目录(文件) ...
创建c1挂载/root/data到/root/data_container
docker run -it --name=c1 -v /root/data:/root/data_container centos:7 /bin/bash
关闭容器,可以看到数据卷数据文件还在
docker stop c1
宿主机目录还在
删除容器c1
docker rm c1
宿主机目录还在
重新恢复c1
docker run -it --name=c1 -v ~/data:/root/data_container centos:7 /bin/bash
注意在容器中不能写~
一个容器挂载多个数据卷
docker run -it --name=c2 \
-v ~/data2:/root/data2 \
-v ~/data3:/root/data3 \
centos:7
两个容器挂载同一个数据卷
docker run -it --name=c3 -v /root/data:/root/data_container centos:7 /bin/bash docker run -it --name=c4 -v /root/data:/root/data_container centos:7 /bin/bash
在一个容器中修改文件,看到另一个容器也跟着
配置数据卷容器
创建启动c3数据卷容器,使用 –v 参数 设置数据卷
docker run –it --name=c3 –v /volume centos:7 /bin/bash
这里没有指定宿主机目录,默认生成一个宿主机目录
docker inspect c3 #查看c3
创建启动 c1 c2 容器,使用 –-volumes-from 参数 设置数据卷
docker run -it --name=c1 --volumes-from c3 centos:7 /bin/bash
docker run -it --name=c2 --volumes-from c3 centos:7 /bin/bash
使用 c3数据卷容器创建c1,c2,这时即使c3关闭不影响c3,c4交互
Docker应用部署
Mysql
拉取mysql镜像
docker pull mysql:5.6
创建容器,设置端口映射、目录映射
# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.6
进入容器,操作mysql
docker exec -it c_mysql /bin/bash
mysql -uroot -p123456
show databases;
create database db1;
Tomcat部署
拉取tomcat镜像
docker pull tomcat
创建容器,设置端口映射、目录映射
# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat
Nginx部署
拉取nginx镜像
docker pull nginx
创建容器,设置端口映射、目录映射
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx
Redis部署
拉取redis镜像
docker pull redis:5.0
创建容器,设置端口映射
docker run -id --name=c_redis -p 6379:6379 redis:5.0
使用外部机器连接redis
./redis-cli.exe -h 192.168.220.12 -p 6379
keys *
set name lxs
get name
Dockerfile
Docker镜像原理
镜像制作
容器转镜像
docker commit 容器id 镜像名称:版本号
docker save -o 压缩文件名称 镜像名称:版本号
docker load –i 压缩文件名称
# 创建tomcat镜像
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat
# 进入tomcat镜像
docker exec -it c_tomcat /bin/bash
#创建a.txt b.txt
cd ~
touch a.txt b.txt
#容器转镜像
docker commit 28b8d4dc9744 lxs_tomcat:1.0
#压缩镜像
docker save -o lxs_tomcat.tar lxs_tomcat:1.0
#删除原来镜像
docker rmi lxs_tomcat:1.0
#从压缩文件加载镜像
docker load -i lxs_tomcat.tar
#产生镜像
docker run -it --name=new_tomcat lxs_tomcat:1.0 /bin/bash
#进入查看内容
docker exec -it c_tomcat /bin/bash
#可以看到a.txt b.txt存在,而webapps/test不存在
dockerfile
自定义centos7镜像
- 定义父镜像:FROM centos:7
- 定义作者信息:MAINTAINER cg cg@lxs.cn
- 执行安装vim命令: RUN yum install -y vim
- 定义默认的工作目录:WORKDIR /usr
- 定义容器启动执行的命令:CMD /bin/bash
- 通过dockerfile构建镜像:docker bulid –f dockerfile文件路径 –t 镜像名称:版本 .
mkdir ~/docker-files
cd ~/docker-files
vim centos_dockerfile
dockerfile具体内容
FROM centos:7
MAINTAINER cg <cg@126.com>
RUN yum install -y vim
WORKDIR /usr
CMD /bin/bash
build
docker build -f ./centos_dockerfile -t lxs_centos:1 .
docker run -it --name=c2 lxs_centos:1
发布springboot项目
- 定义父镜像:FROM java:8
- 定义作者信息:MAINTAINER cg cg@163.com
- 将jar包添加到容器: ADD springboot.jar app.jar
- 定义容器启动执行的命令:CMD [“java”,"-jar",“app.jar”]
- 通过dockerfile构建镜像:docker build –f dockerfile文件路径 –t 镜像名称:版本 .
FROM java:8
MAINTAINER cg <cg@163.com>
ADD springboot.jar app.jar
CMD ["java","-jar","app.jar"]
build
docker build –f ./springboot_dockerfile –t app .
docker run -id -p 9000:8080 app
服务编排
Docker Compose
安装Docker Compose
# Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我 们以 编译好的二进制包方式安装在Linux系统中。
sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
# 设置文件可执行权限
chmod +x /usr/local/bin/docker-compose
# 查看版本信息
docker-compose -version
卸载Docker Compose
# 二进制包方式安装的,删除二进制文件即可
rm /usr/local/bin/docker-compose
编排nginx+springboot
使用nginx反向代理到springboo应用
创建docker-compose目录
mkdir ~/docker-compose
cd ~/docker-compose
编写 docker-compose.yml 文件
version: '3'
services:
nginx:
image: nginx
ports:
- 8081:8081
links:
- app
volumes:
- ./nginx/conf.d:/etc/nginx/conf.d
app:
image: app
expose:
- "8080"
创建./nginx/conf.d目录
mkdir -p ./nginx/conf.d
在./nginx/conf.d目录下 编写app.conf文件
server {
listen 8081;
access_log off;
location / {
proxy_pass http://app:8080/hello;
}
}
在~/docker-compose 目录下 使用docker-compose 启动容器
docker-compose up -d # -d表示已守护模式启动
测试访问
http://192.168.238.129/8081
停止
docker-compose down
Docker私有仓库
私有仓库搭建
# 1、拉取私有仓库镜像
docker pull registry
# 2、启动私有仓库容器
docker run -id --name=registry -p 5000:5000 registry
# 3、打开浏览器 输入地址http://私有仓库服务器ip:5000/v2/_catalog,看到{"repositories":[]} 表示私有仓 库 搭建成功
# 4、修改daemon.json
vim /etc/docker/daemon.json
# 在上述文件中添加一个key,保存退出。此步用于让 docker 信任私有仓库地址;注意将私有仓库服务器ip修改为自 己私有仓库服务器真实ip
{"insecure-registries":["私有仓库服务器ip:5000"]}
{"insecure-registries":["192.168.238.129:5000"]}
# 5、重启docker 服务
systemctl restart docker
docker start registry
查看registry镜像情况
http://192.168.238.129:5000/v2/_catalog
将镜像上传至私有仓库
# 1、标记镜像为私有仓库的镜像
docker tag centos:7 192.168.238.129:5000/centos:7
# 2、上传标记的镜像
docker push 192.168.238.129:5000/centos:7
从私有仓库拉取镜像
#拉取镜像
docker pull 192.168.238.129:5000/centos:7