0

0

【程序源代码】docker精选操作

爱谁谁

爱谁谁

发布时间:2025-07-15 09:44:20

|

180人浏览过

|

来源于php中文网

原创

01

【总体介绍】

1、简介

Docker是一个开源的应用容器引擎,是一种轻量级的容器技术。Docker支持将软件编译成镜像,然后在镜像中配置各种软件,将其发布出去,其他用户可以直接使用这个镜像。运行中的镜像称为容器,容器的启动速度非常快。

2、核心概念

  • Docker主机(Host):安装了Docker程序的机器(Docker直接安装在操作系统之上)。
  • Docker客户端(Client):用于连接Docker主机进行操作。
  • Docker仓库(Registry):用来保存各种打包好的软件镜像。
  • Docker镜像(Images):打包好的软件镜像,存放在Docker仓库中。
  • Docker容器(Container):镜像启动后的实例,称为容器。容器是独立运行的一个或一组应用。

使用Docker的步骤:

  1. 安装Docker。
  2. 在Docker仓库中找到软件对应的镜像。
  3. 使用Docker运行镜像,生成一个Docker容器。
  4. 对容器的启动和停止即是对软件的启动和停止。

3、安装Docker

  1. 安装Linux虚拟机:
    • 安装VMWare或VirtualBox。
    • 导入虚拟机文件centos7-atguigu.ova。
    • 双击启动Linux虚拟机,使用root/123456登录。
    • 使用客户端连接Linux服务器进行命令操作。
    • 设置虚拟机网络,选择桥接网络并选好网卡,接入网线。
    • 设置好网络后,使用命令重启虚拟机网络。
service network restart
  • 查看Linux的IP地址。
ip addr
  • 使用客户端连接Linux。
  1. 在Linux虚拟机上安装Docker:
1、检查内核版本,必须是3.10及以上
uname -r
2、安装Docker
yum install docker
3、输入y确认安装
4、启动Docker
[root@localhost ~]# systemctl start docker
[root@localhost ~]# docker -v
Docker version 1.12.6, build 3e8e77d/1.12.6
5、开机启动Docker
[root@localhost ~]# systemctl enable docker
Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.
6、停止Docker
systemctl stop docker

4、Docker常用命令与操作

  1. 镜像操作
操作 命令 说明
检索 docker search 关键字 eg:docker search redis 经常在Docker Hub上检索镜像的详细信息,如镜像的TAG。
拉取 docker pull 镜像名:tag :tag是可选的,tag表示标签,多为软件的版本,默认是latest。
列表 docker images 查看所有本地镜像。
删除 docker rmi image-id 删除指定的本地镜像。

https://www.php.cn/link/0fe53ab665b7845ea7be17becdd77850

  1. Tomcat容器操作

软件镜像(如QQ安装程序)——运行镜像——产生一个容器(正在运行的软件,如运行的QQ)。

步骤:

1、搜索镜像
[root@localhost ~]# docker search tomcat
2、拉取镜像
[root@localhost ~]# docker pull tomcat
3、根据镜像启动容器
docker run --name mytomcat -d tomcat:latest
4、docker ps 查看运行中的容器
5、停止运行中的容器
docker stop 容器的id
6、查看所有的容器
docker ps -a
7、启动容器
docker start 容器id
8、删除一个容器
docker rm 容器id
9、启动一个做了端口映射的tomcat
[root@localhost ~]# docker run -d -p 8888:8080 tomcat
docker run --privileged -it -d --name tomcat02 -p 8099:8080 tomcat
-d:后台运行
-p: 将主机的端口映射到容器的一个端口 主机端口:容器内部的端口
10、为了演示简单,关闭Linux的防火墙
service firewalld status;查看防火墙状态
service firewalld stop:关闭防火墙
11、查看容器的日志
docker logs container-name/container-id
更多命令参看https://docs.docker.com/engine/reference/commandline/docker/
可以参考每一个镜像的文档
  1. 安装MySQL示例
docker pull mysql

错误的启动:

[root@localhost ~]# docker run --name mysql01 -d mysql
42f09819908bb72dd99ae19e792e0a5d03c48638421fa64cce5f8ba0f40f5846
mysql退出了
[root@localhost ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                      PORTS               NAMES
42f09819908b        mysql               "docker-entrypoint.sh"   34 seconds ago     Exited (1) 33 seconds ago                       mysql01
538bde63e500        tomcat              "catalina.sh run"        About an hour ago  Exited (143) About an hour ago                   compassionate_goldstine
c4f1ac60b3fc        tomcat              "catalina.sh run"        About an hour ago  Exited (143) About an hour ago                   lonely_fermi
81ec743a5271        tomcat              "catalina.sh run"        About an hour ago  Exited (143) About an hour ago                   sick_ramanujan
//错误日志
[root@localhost ~]# docker logs 42f09819908b
error: database is uninitialized and password option is not specified 
You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD;这三个参数必须指定一个

正确的启动:

[root@localhost ~]# docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
b874c56bec49fb43024b3805ab51e9097da779f2f572c22c695305dedd684c5f
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
b874c56bec49        mysql               "docker-entrypoint.sh"   4 seconds ago      Up 3 seconds        3306/tcp            mysql01

做了端口映射:

[root@localhost ~]# docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
ad10e4bc5c6a0f61cbad43898de71d366117d120e39db651844c0e73863b9434
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
ad10e4bc5c6a        mysql               "docker-entrypoint.sh"   4 seconds ago      Up 2 seconds        0.0.0.0:3306->3306/tcp   mysql02

几个其他的高级操作:

docker run --name mysql03 -v /conf/mysql:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
把主机的/conf/mysql文件夹挂载到 mysqldocker容器的/etc/mysql/conf.d文件夹里面
改mysql的配置文件就只需要把mysql配置文件放在自定义的文件夹下(/conf/mysql)
docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
指定mysql的一些配置参数

02

【源码使用说明】

05

【视频]

大家关注视频号

【联系方式]

方科网络ERP图文店
方科网络ERP图文店

方科网络ERP图文店II版为仿代码站独立研发的网络版ERP销售程序。本本版本为方科网络ERP图文店版的简化版,去除了部分不同用的功能,使得系统更加精炼实用。考虑到图文店的特殊情况,本系统并未制作出入库功能,而是将销售作为重头,使用本系统,可以有效解决大型图文店员工多,换班数量多,订单混杂不清的情况。下单、取件、结算分别记录操作人员,真正做到订单全程跟踪!无限用户级别,不同的用户级别可以设置不同的价

下载

公众号ID: itcode

【公众号二维码, 扫一扫吧】

【程序源代码】docker精选操作

微信ID: itcoder

【微信二维码, 扫一扫吧】

【程序源代码】docker精选操作

【写作说明】以上文章属于此公众号原创所有,如需转载请注明出处。【免责申明】本公众号不是广告商,也没有为其他三方网站或者个人做广告宣传。文章发布源代码和文章均来源于各类开源网站社区或者是小编在项目中、学习中整理的一些实例项目。主要目的是将开源代码分享给喜欢编程、有梦想的程序员,希望能帮助到你们与他们共同成长。其中用户产生的一些自愿下载、打赏或者付费行为,原则与平台没有直接关系。如果涉及开源程序侵犯到原作者相关权益,可联系小编进行相关处理。

【投稿邮箱】315997972@qq.com

目前已有1000000+优秀的程序员加入我们

【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作【程序源代码】docker精选操作

【你的每一份打赏就是对我最真诚的鼓励】

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

663

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

529

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

【李炎恢】ThinkPHP8.x 后端框架课程
【李炎恢】ThinkPHP8.x 后端框架课程

共50课时 | 4.4万人学习

nginx浅谈
nginx浅谈

共15课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号