运维

Docker简单使用

2019-01-21  本文已影响22人  GongZH丶

https://docs.docker.com/
http://www.dockerinfo.net/document
https://yeasy.gitbooks.io/docker_practice/introduction/
https://blog.myzony.com/linux-xia-de-docker-an-zhuang-yu-shi-yong/

Docker安装

docker有企业版、社区版,我们使用社区版。

windows

Docker for Windows 支持 64 位版本的 Windows 10 Pro,且必须开启 Hyper-V。
下载好之后双击 Docker for Windows Installer.exe 开始安装。
然后启动
Docker CE 启动之后会在 Windows 任务栏出现鲸鱼图标。

Mac安装

使用 Homebrew 安装:

brew cask install docker

手动下载安装:
如果需要手动下载,请点击以下链接下载 StableEdge 版本的 Docker for Mac。
https://docs.docker-cn.com/docker-for-mac/install/#download-docker-for-mac

与macOS 其它软件一样,安装也非常简单,双击下载的 .dmg 文件,然后将那只叫 Moby 的鲸鱼图标拖拽到 Application 文件夹即可(其间需要输入用户密码)。

linux安装 (CentOS 7.6)

1.设置阿里云镜像源

sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 

2.安装依赖包

sudo yum install -y yum-utils device-mapper-persistent-data lvm2

3.安装 Docker-CE
重建 Yum 缓存。
安装 Docker-CE ,请执行一下命令进行安装:

sudo yum install docker-ce

4.启动 Docker-CE

sudo systemctl enable docker
sudo systemctl start docker

基本概念

Docker 包括三个基本概念
http://www.cnblogs.com/SzeCheng/p/6822905.html
http://www.dockerinfo.net/image%E9%95%9C%E5%83%8F
https://yeasy.gitbooks.io/docker_practice/basic_concept/image.html
镜像(Image)
仓库(Repository)
容器(Container)
理解了这三个概念,就理解了 Docker 的整个生命周期。

镜像

镜像可以用来创建 Docker 容器,一个镜像可以创建很多容器。Docker 提供了一个很简单的机制来创建镜像或者更新现有的镜像,用户甚至可以直接从其他人那里下载一个已经做好的镜像来直接使用。

仓库

仓库(Repository)是集中存放镜像文件的场所。
仓库分为公开仓库(Public)和私有仓库(Private)两种形式。最大的公开仓库是 Docker Hub,存放了数量庞大的镜像供用户下载。国内的公开仓库包括 时速云 、网易云 等,可以提供大陆用户更稳定快速的访问。当然,用户也可以在本地网络内创建一个私有仓库。

当用户创建了自己的镜像之后就可以使用 push 命令将它上传到公有或者私有仓库,这样下次在另外一台机器上使用这个镜像时候,只需要从仓库上 pull 下来就可以了。

容器

Docker 利用容器(Container)来运行应用。容器是从镜像创建的运行实例。它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台。可以把容器看做是一个简易版的 Linux 环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。

常用命令

1.拉取镜像

docker pull

2.删除容器

docker rm <容器名 or ID>

3.查看容器日志

docker logs -f <容器名 or ID>

4.查看正在运行的容器

docker ps
docker ps -a # 为查看所有的容器,包括已经停止的。

5.删除所有容器

docker rm $(docker ps -a -q)

6.停止、启动、杀死指定容器

docker start <容器名 or ID> # 启动容器
docker stop <容器名 or ID> # 启动容器
docker kill <容器名 or ID> # 杀死容器

7.查看所有镜像

docker images

8.拉取镜像

docker search <镜像>  在docker hub上搜索镜像

docker pull <镜像名:tag> 拉取镜像
# 例如以下代码
docker pull sameersbn/redmine:latest

9.后台运行

docker run -d <Other Parameters>
# 例如
docker run -d -p 127.0.0.1:33301:22 centos6-ssh

10.暴露端口

# 一共有三种形式进行端口映射

docker -p ip:hostPort:containerPort # 映射指定地址的主机端口到容器端口
# 例如:docker -p 127.0.0.1:3306:3306 映射本机3306端口到容器的3306端口

docker -p ip::containerPort # 映射指定地址的任意可用端口到容器端口
# 例如:docker -p 127.0.0.1::3306 映射本机的随机可用端口到容器3306端口

docer -p hostPort:containerPort # 映射本机的指定端口到容器的指定端口
# 例如:docker -p 3306:3306 # 映射本机的3306端口到容器的3306端口

11.挂载数据卷

docker -v /home/data:/opt/data # 这里/home/data 指的是宿主机的目录地址,后者则是容器的目录地址

12.进入容器

docker exec -it <容器名称> bash
# 例如:docker exec -it testmysql bash

13.查看容器详细信息

docker inspect <容器名称>

在Docker中运行Mysql

1、拉取镜像

docker pull mysql

2、创建本机目录用于存放文件
(注意,创建了挂载数据卷后,要将配置文件放在挂载的目录下,不然容器会启动失败,因为mysql启动时要读取配置文件)

mkdir -p ~/mysqlData/conf ~/mysqlData/data
//conf: 目录将映射为 mysql 容器的配置文件my.cnf。
//data: 目录将映射为 mysql 容器的数据存储位置。
vi ~/mysqlData/conf/my.cnf

3、使用mysql镜像运行容器

docker run -itd -p 3307:3306 --name testmysql1 -v ~/mysqlData/conf:/etc/mysql/conf.d -v ~/mysqlData/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql

//-p 3307:3306:将容器的3307端口映射到主机的3306端口
//-name testmysql1:将容器命名为testmysql1
//-v ~/mysqlData/conf:/etc/mysql/conf.d:将主机中的~/mysqlData/conf挂载到容器的/etc/mysql/conf.d
//-v ~/mysqlData/data:/var/lib/mysql:将主机中的~/mysqlData/data挂载到容器的/var/lib/mysql

4、配置my.cnf文件

5、容器重启

docker restart testmysql1

6、进入容器

docker exec -it testmysql1 bash

7、登陆mysql,设置权限

    mysql -u root -p
    
    grant all PRIVILEGES on *.* to root@'%' WITH GRANT OPTION;
    ALTER user 'root'@'%' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
    ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
    FLUSH PRIVILEGES;

8、打开Navicat测试连接

9、建库建表,加数据后,查看宿主机上挂载的数据卷是否有数据,在 ~/mysqlData/data 目录下查看

    docker exec -it testmysql1 bash

10、挂载数据卷后,数据库数据存储文件就可以持久化在宿主机上,后面运行新容器的时候可以挂载已有数据存储文件的目录,容器运行后就有数据了

在Docker中运行Nginx

1、拉取镜像

    docker pull nginx

2、创建本机目录用于存放文件

    mkdir -p ~/nginx/www ~/nginx/logs ~/nginx/conf
    //www: 目录将映射为 nginx 容器配置的虚拟目录。
    //logs: 目录将映射为 nginx 容器的日志目录。
    //conf: 目录里的配置文件将映射为 nginx 容器的配置文件。
    vi ~/nginx/conf/nginx.conf

    chmod 777 nginx.conf

3、使用nginx镜像运行容器

 docker run -p 80:80 --name mynginx      -v ~/nginx/www:/www      -v ~/nginx/conf/nginx.conf:/etc/nginx/nginx.conf      -v ~/nginx/logs:/wwwlogs     -d nginx
 //-p 80:80:将容器的80端口映射到主机的80端口
 //-name mynginx:将容器命名为mynginx
 //-v ~/nginx/www:/www:将主机中的www挂载到容器的/www
 //-v ~/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:将主机中的nginx.conf挂载到容器的/etc/nginx/nginx.conf
 //-v ~/nginx/logs:/wwwlogs:将主机中的logs挂载到容器的/wwwlogs

4、配置nginx.conf文件

5、容器重启

上一篇下一篇

猜你喜欢

热点阅读