Docker学习笔记

160 阅读4分钟

Docker

1 Docker安装

yum install -y docker-ce
docker -v

2 配置阿里云的镜像加速器

 控制台——>容器镜像服务——>镜像加速器

3 Docker命令

3.1 docker服务相关命令
-- 启动docker
systemctl start docker 
-- 查看docker状态
systemctl status docker
-- 停止docker
systemctl stop docker
-- 重启docker
systemctl restart docker
-- 设置开机自启
systemctl enable docker
3.2 docker镜像相关命令
-- 查看镜像
docker images
-- 查看所有镜像id
docker images -q
-- 搜索镜像
docker search 镜像名称
-- 拉取镜像
docker pull 镜像名称:版本号(不指定版本号,下载最新的latest)
-- 删除镜像
docker rmi 镜像id 
-- 删除所有本地镜像
docker rmi `docker images -q`
3.3 docker容器相关命令
-- 查看正在运行的容器
docker ps
-- 查看所有容器
docker ps -a
-- 创建并启动容器(-it交互式-id守护式--name容器命名)
docker run -it --name=ubuntu1 ubuntu /bin/bash  退出,容器关闭 | docker run -id --name=ubuntu1 ubuntu /bin/bash  退出,容器不会关闭
-- 进入守护式容器
docker exec -it ubuntu2 /bin/bash
-- 停止容器
docker stop 容器名称
-- 启动容器
docker start 容器名称
docker start ubuntu2 | docker start 38f9d6dcb911
-- 删除容器
docker rm 容器名称
docker rm ubuntu2 | docker rm 38f9d6dcb911
-- 删除所有容器
docker rm `docker ps -aq`
-- 查看容器信息
docker inspect 容器名称

4 数据卷

-- 配置数据卷
docker run ... -v 宿主机目录:容器内目录 ...
docker run -it --name=ubuntu1 -v /root/data:/root/data_container ubuntu /bin/bash

-- 数据卷容器
docker run -it --name=u3 -v /volume ubuntu          -- u3作为数据卷容器
docker run -it --name=u1 --volumes-from u3 ubuntu   -- u1挂载到u3上
docker run -it --name=u2 --volumes-from u3 ubuntu   -- u2挂载到u3上

5 应用部署

5.1 MySQL
-- 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql

-- 安装MySQL
docker run -id \
-p 3306: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.7

-- 验证
docker exec -it c_mysql /bin/bash
mysql -uroot -p123456
navicat连接虚拟机的MySQL
5.2 Tomcat
-- 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat

-- 安装tomcat
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat 
5.3 Nginx
-- 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf

-- 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf

-- nginx配置
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;
}

-- 回到nginx目录再下载
cd nginx

-- 下载nginx
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
5.4 Redis
docker run -id --name=c_redis -p 6379:6379 redis:6.0

-- 外部机器连接
./redis-cli.exe -h 192.168.149.135 -p 6379

6 Dockerfile

6.1 案例一(centos7增加vim命令)
-- 编写Dockerfile配置
FROM centos:7
MAINTAINER king <king@qq.com>
RUN yum install -y vim
WORKDIR /usr
CMD /bin/bash

-- 构建
docker build -f 配置文件 -t 新镜像名称:版本号 . | docker build -f centos-dockerfile -t king-centos:1.0 .
6.2 案例二(springboot项目部署虚拟机)
-- 1.准备好springboot jar包并传至宿主机的根目录(fxtp完成)

-- 2.创建docker-files目录,并把jar包移动进去
mkdir docker-files
mv xxx.jar ./docker-files/

-- 3.创建dockerfile文件(springboot-dockerfile)并编辑
FROM java:8
MAINTAINER king <king@qq.com>
ADD dockerfile-0.0.1-SNAPSHOT.jar app.jar
CMD java -jar app.jar

-- 4.根据dockerfile制作镜像
docker build -f springboot-dockerfile -t app .

-- 5.启动并做端口映射 
docker run -id -p 3986:8080 app

-- 6.访问192.168.126.129:3986/hello 显示hello docker... 部署成功!

7 Docker Compose

7.1 安装
-- Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我 们以编译好的二进制包方式安装在Linux系统中。 
curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
-- 设置文件可执行权限 
chmod +x /usr/local/bin/docker-compose
-- 查看版本信息 
docker-compose -version
7.2 卸载
-- 二进制包方式安装的,删除二进制文件即可
rm /usr/local/bin/docker-compose
7.3 使用docker compose编排nginx+springboot项目
-- 1.创建docker-compose目录
mkdir ~/docker-compose
cd ~/docker-compose

-- 2.编写 docker-compose.yml 文件
version: '3'
services:
  nginx:
   image: nginx
   ports:
    - 80:80
   links:
    - app
   volumes:
    - ./nginx/conf.d:/etc/nginx/conf.d
  app:
    image: app
    expose:
      - "8080"
      
-- 3.创建./nginx/conf.d目录
mkdir -p ./nginx/conf.d

-- 4.在./nginx/conf.d目录下 编写king.conf文件
server {
    listen 80;
    access_log off;

    location / {
        proxy_pass http://app:8080;
    }
   
}

-- 5.在~/docker-compose 目录下 使用docker-compose 启动容器
docker-compose up

-- 6.测试访问
http://192.168.126.131/hello

8 私有仓库

8.1 私有仓库搭建
-- 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"]} 

-- 5、重启docker 服务 
systemctl restart docker
docker start registry
8.2 将镜像上传至私有仓库
-- 1、标记镜像为私有仓库的镜像     
docker tag centos:7 私有仓库服务器IP:5000/centos:7
 
-- 2、上传标记的镜像     
docker push 私有仓库服务器IP:5000/centos:7
8.3 从私有仓库拉取镜像
#拉取镜像 
docker pull 私有仓库服务器ip:5000/centos:7