Docker23---常用命令和应用部署

    技术2022-07-12  80

    目录

    常用命令1.镜像相关命令(1)查看镜像(2)搜索镜像(3) 拉取镜像(4)删除镜像 2 容器相关命令(1) 查看容器(2)创建与启动容器Ⅰ交互式方式创建容器Ⅱ守护式方式创建容器: (3)停止与启动容器(4)文件拷贝(5) 目录挂载(6)查看容器IP地址(7)删除容器 应用部署1.MySQL部署(1)拉取mysql镜像(2)创建容器(3)远程登录mysql 2.tomcat部署(1)拉取镜像(2)创建容器 3 Nginx部署(1)拉取镜像(2)创建Nginx容器 4 Redis部署(1)拉取镜像(2)创建容器 总结

    相关文章 Docker总结1/3—理论篇 Docker总结3/3—备份迁移和仓库

    常用命令

    1.镜像相关命令

    (1)查看镜像

    docker images

    镜像内容含义REPOSITORY镜像名称TAG镜像标签IMAGE ID镜像IDCREATED镜像的创建日期(不是获取该镜像的日期)SIZE镜像大小

    这些镜像都是存储在Docker宿主机的/var/lib/docker目录下

    (2)搜索镜像

    如果你需要从网络中查找需要的镜像,可以通过以下命令搜索

    docker search 镜像名称 内容含义NAME仓库名称DESCRIPTION镜像描述STARS用户评价,反应一个镜像的受欢迎程度OFFICIAL是否官方AUTOMATED自动构建,表示该镜像由Docker Hub自动构建流程创建的

    (3) 拉取镜像

    拉取镜像就是从中央仓库中下载镜像到本地

    docker pull 镜像名称

    (4)删除镜像

    按镜像ID删除镜像

    docker rmi 镜像ID

    删除所有镜像(删除镜像需要保证,镜像中没有容器,否则需要先删除容器,再删除镜像。)

    docker rmi `docker images -q`

    2 容器相关命令

    (1) 查看容器

    查看正在运行的容器

    docker ps

    查看所有容器

    docker ps –a

    查看最后一次运行的容器

    docker ps –l

    查看停止的容器

    docker ps -f status=exited

    (2)创建与启动容器

    创建容器常用的参数说明:

    创建容器命令: docker run

    命 令含义-i运行容器-t容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端–name为创建的容器命名-v目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上-d在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。-p端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

    Ⅰ交互式方式创建容器

    通过ps命令查看,发现可以看到启动的容器,状态为启动状态

    docker run -it --name=容器名称 镜像名称:标签 /bin/bash

    退出当前容器

    exit

    Ⅱ守护式方式创建容器:

    docker run -di --name=容器名称 镜像名称:标签

    登录守护式容器方式:

    docker exec -it 容器名称 (或者容器ID) /bin/bash 交互式创建容器守护式创建容器直接进入容器内部,退出之后,容器停止。不会容器内部,exec进入容器内部之后,再退出,容器依然运行状态。

    (3)停止与启动容器

    停止容器:

    docker stop 容器名称(或者容器ID)

    启动容器:

    docker start 容器名称(或者容器ID)

    (4)文件拷贝

    无论容器是否启动,都可以进行文件拷贝。

    如果我们需要将文件拷贝到容器内可以使用cp命令

    docker cp 需要拷贝的文件或目录 容器名称:容器目录

    也可以将文件从容器内拷贝出来

    docker cp 容器名称:容器目录 需要拷贝的文件或目录

    (5) 目录挂载

    我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。

    创建容器 添加-v参数 后边为 宿主机目录:容器目录

    例如:

    docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos3 centos:7

    如果你共享的是多级的目录,可能会出现权限不足的提示。

    这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题

    (6)查看容器IP地址

    我们可以通过以下命令查看容器运行的各种数据

    docker inspect 容器名称(容器ID)

    也可以直接执行下面的命令直接输出IP地址

    docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)

    (7)删除容器

    删除指定的容器:

    docker rm 容器名称(容器ID)

    应用部署

    1.MySQL部署

    (1)拉取mysql镜像

    docker pull centos/mysql-57-centos7

    (2)创建容器

    docker run -di --name=tensquare_mysql -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql 参数含义–name自定义的Mysql的名称-p端口映射,格式为 宿主机映射端口:容器运行端口-e添加环境变量 MYSQL_ROOT_PASSWORD 是root用户的登陆密码 输入docker ps 查看映射的端口号

    (3)远程登录mysql

    连接宿主机的IP ,指定端口为33306 本地测试连接:

    2.tomcat部署

    (1)拉取镜像

    docker pull tomcat:7-jre7

    (2)创建容器

    创建容器 -p表示地址映射 (端口映射+目录挂载)

    docker run -di --name=mytomcat -p 9000:8080 -v /usr/local/webapps:/usr/local/tomcat/webapps tomcat:7-jre7

    【测试tomcat部署内容】

    上传cas.war文件

    转移cas.war文件到刚才创建的目录 mv cas.war /usr/local/web

    浏览器输入 “服务器IP地址:映射的端口号/cas” 即可看到上传的文件页面:

    3 Nginx部署

    (1)拉取镜像

    docker pull nginx

    (2)创建Nginx容器

    (端口映射)

    docker run -di --name=mynginx -p 80:80 nginx

    【测试nginx部署的页面】

    查看上传的页面的位置(此步骤可以不操作)

    [root@localhost ~]# docker exec -it mynginx /bin/bash root@348ce53d721c:/# dir bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var root@348ce53d721c:/# cd etc/nginx root@348ce53d721c:/etc/nginx# dir conf.d fastcgi_params koi-utf koi-win mime.types modules nginx.conf scgi_params uwsgi_params win-utf root@348ce53d721c:/etc/nginx# cd conf.d root@348ce53d721c:/etc/nginx/conf.d# dir default.conf root@348ce53d721c:/etc/nginx/conf.d# cat default.conf root@348ce53d721c:/etc/nginx/conf.d# cd /usr/share/nginx/html/ root@348ce53d721c:/usr/share/nginx/html# dir 50x.html index.html root@348ce53d721c:/usr/share/nginx/html# exit exit [root@localhost ~]# dir anaconda-ks.cfg html mynginx.tar dist 上传文件到根目录 sftp> put -r 文件夹路径 移动文件到创建的mynginx容器下 [root@localhost ~]# mv dist html [root@localhost ~]# docker cp html mynginx:/usr/share/nginx 打开浏览器输入:服务器IP地址,访问上传的页面即可。

    4 Redis部署

    (1)拉取镜像

    docker pull redis

    (2)创建容器

    (端口映射)

    docker run -di --name=myredis -p 6379:6379 redis

    【测试redis部署】

    #查看命令redis的id [root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 40a25b0c17b5 redis "docker-entrypoint.s…" 11 minutes ago Up 11 minutes 0.0.0.0:6379->6379/tcp myredis #进入redis容器内部 [root@localhost ~]# docker exec -it 61afc2919bb6 redis-cli #设置一个值、并将值取出 127.0.0.1:6379> set hello stephanie OK 127.0.0.1:6379> get hello "stephanie"

    [redis被外网访问] redis自带安全机制,默认情况下,不能被外网访问。 通过服务端,开发端口,即可实现外网访问redis。

    ①官网下载redis.conf并修改端口号为外网可访问的端口号。 0.0.0.0为所有网络都可访问,但不安全。

    ②上传redis文件

    sftp> put D:\material\Netease\redis.conf

    ③目录挂载 (实现文件互传)

    docker run -p 6379:6379 --name redis -v /data/redis/redis.conf:/etc/redis/redis.conf -v /data/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes

    ④移动文件到redis的目录

    mv redis.conf /data/redis/redis.conf

    ⑤查看redis.conf文件内容,完成目录

    [root@localhost redis]# cd /data/redis [root@localhost redis]# ll data redis.conf [root@localhost redis]# cd redis.conf [root@localhost redis]# vi redis.conf [root@localhost redis.conf]# vi redis.conf

    总结

    到这里Docker常用命令,和常用软件的部署就结束了。

    Processed: 0.011, SQL: 9