docker中怎么创建MariaDB镜像
发表于:2024-11-28 作者:千家信息网编辑
千家信息网最后更新 2024年11月28日,这篇文章将为大家详细讲解有关docker中怎么创建MariaDB镜像,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、基于commit命令方式创建do
千家信息网最后更新 2024年11月28日docker中怎么创建MariaDB镜像
这篇文章将为大家详细讲解有关docker中怎么创建MariaDB镜像,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
一、基于commit命令方式创建
docker的安装
[root@test01 ~]# yum install docker[root@test01 ~]# systemctl enable docker[root@test01 ~]# systemctl start docker
下载本地镜像
[root@test01 ~]# docker pull centos:7.4.1708[root@test01 ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZEdocker.io/centos 7.4.1708 3afd47092a0e 3 months ago 196.6 MB
创建交互型容器
[root@test01 ~]# docker run -it --name="mysql_server" centos /bin/bash
4.安装mariadb服务
[root@e8126d0481d2 /]# yum -y install mariadb-server net-tools
初始化mariadb
[root@e8126d0481d2 /]# mysql_install_db --user=mysql
后台启动mariadb服务
[root@e8126d0481d2 /]# mysqld_safe &[1] 114[root@e8126d0481d2 /]# 180210 13:45:27 mysqld_safe Logging to '/var/log/mariadb/mariadb.log'.180210 13:45:27 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql[root@e8126d0481d2 /]# netstat -tunplActive Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN -
创建mariadb登录密码,并可以指定ip登录
[root@e8126d0481d2 /]# mysqladmin -u root password 'kingsoft'[root@e8126d0481d2 /]# mysql -u root -pEnter password:MariaDB [(none)]> show databases;MariaDB [(none)]> use mysql;MariaDB [mysql]> select Host from user where user='root';MariaDB [mysql]> grant all privileges on *.* to 'root'@'%' identified by 'kingsoft' with grant option;MariaDB [mysql]> update user set password=password('kingsoft') where user='root' and host='e8126d0481d2';MariaDB [mysql]> flush privileges;MariaDB [mysql]> exit
容器登录验证
[root@e8126d0481d2 /]# mysql -u root -h 172.17.0.2 -pEnter password:MariaDB [(none)]> exit
创建容器启动脚本
[root@e8126d0481d2 ~]# cat run.sh#!/bin/shmysqld_safe
创建镜像
[root@test01 ~]# docker ps -aCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMESe8126d0481d2 centos "/bin/bash" 11 minutes ago Exited (0) 8 seconds ago mysql_server[root@test01 ~]# docker commit mysql_server mariadb:1.0
创建容器
[root@test01 ~]# docker run -d -p 13306:3306 mariadb:1.0 /root/run.sh[root@test01 ~]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMESeed3e88a1261 mariadb:1.0 "mysqld_safe" 4 seconds ago Up 3 seconds 0.0.0.0:13306->3306/tcp romantic_hamilton
主机登录验证
[root@test01 ~]# yum -y install mariadb[root@test01 ~]# mysql -u root --port=13306 -pMariaDB [(none)]>
二、基于Dockerfile方式创建
设置创建目录和文件
[root@test01 ~]# mkdir mariadb_dockerfile && cd mariadb_dockerfile[root@test01 mariadb_dockerfile]# touch db_init.sh [root@test01 mariadb_dockerfile]# touch run.sh
编辑Dockerfile等文件
Dockerfile
[root@test01 mariadb_dockerfile]# cat Dockerfile #使用的基础镜像FROM centos:7.4.1708#添加作者信息MAINTAINER liuxin 842887233@qq.com#安装mariadb数据库RUN yum -y install mariadb-server#设置环境变量,便于管理ENV MARIADB_USER rootENV MARIADB_PASS kingsoft#让容器支持中文ENV LC_ALL en_US.UTF-8#初始化数据库ADD db_init.sh /root/db_init.shRUN chmod 775 /root/db_init.shRUN /root/db_init.sh#导出端口EXPOSE 3306#添加启动文件ADD run.sh /root/run.shRUN chmod 775 /root/run.sh#设置默认启动命令CMD ["/root/run.sh"]
db_init.sh
[root@test01 mariadb_dockerfile]# cat db_init.sh #!/bin/bashmysql_install_db --user=mysqlsleep 3mysqld_safe &sleep 3#mysqladmin -u "$MARIADB_USER" password "$MARIADB_PASS"mysql -e "use mysql; grant all privileges on *.* to '$MARIADB_USER'@'%' identified by '$MARIADB_PASS' with grant option;"h=$(hostname)mysql -e "use mysql; update user set password=password('$MARIADB_PASS') where user='$MARIADB_USER' and host='$h';"mysql -e "flush privileges;"
run.sh
[root@test01 mariadb_dockerfile]# cat run.sh #!/bin/bashmysqld_safe
创建镜像
[root@test01 mariadb_dockerfile]# docker build -t liuxin/centos-mariadb:v1 ./
创建容器
[root@test01 mariadb_dockerfile]# docker run -d -p 13306:3306 liuxin/centos-mariadb:v1 /root/run.sh[root@test01 mariadb_dockerfile]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES7743527ac603 liuxin/centos-mariadb:v1 "/root/run.sh" 5 seconds ago Up 3 seconds 0.0.0.0:13306->3306/tcp nostalgic_mirzakhani
登录验证
[root@test01 mariadb_dockerfile]# mysql -uroot -h 127.0.0.1 --port=13306 -pEnter password: Welcome to the MariaDB monitor. Commands end with ; or \g.Your MariaDB connection id is 1Server version: 5.5.56-MariaDB MariaDB ServerCopyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.MariaDB [(none)]> exit
关于docker中怎么创建MariaDB镜像就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
镜像
容器
登录
文件
验证
内容
命令
数据
数据库
文章
方式
更多
知识
篇文章
服务
不错
主机
作者
信息
变量
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发如何入账
网络安全等级保护costa
互联网金融的科技背景
数据库数量
法人是网络安全第一责任人
济南编程软件开发教程
idea可视化数据库新建
宁夏网络安全违规
火山软件开发 读网页
济宁网络安全宣传周
c支持的数据库
嘉兴软件开发报价
网络安全证书图片排版
oss走服务器带宽
网络安全自查信息报道
大商创服务器配置
服务器带外管理口
数据库中将某些信息写入新表
闵行区软件开发代理价钱
服务器管理常见问题
高斯数据库 应用
无线充电器软件开发真的好难
宝山区创新数据库服务价格查询
服务器高恪
邮件服务器有哪些类型
db2创建管理服务器
计算机网络技术学什么难吗
北京服务器搬迁有哪些云空间
网络技术部 新年计划
平安科技 互联网连州