docker 创建镜像

4 篇文章 0 订阅

demo1 :docker 打包 spring boot 镜像

Dockerfile

# 基础镜像使用Java
FROM java:8
# 作者
MAINTAINER Yonglong Xue
# 将jar包添加到容器中并更名为app.jar
ADD certificate-manager-0.0.1-SNAPSHOT.jar app.jar
# 运行jar包
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
# 指定容器需要映射到主机的端口
EXPOSE 8080

编译、运行

docker image build cert:版本号(不写为最新版) .  (.号不能少)

docker run --network=app --name cert -d -p 8080:8080 cert

 demo2 :docker 打包 mysql 镜像

Dockerfile

# 指定基础镜像,选用docker官方最新mysql镜像
FROM mysql:5.7
# 环境变量设置,设置mysql登陆时不需密码
# ENV MYSQL_ALLOW_EMPTY_PASSWORD yes
# 复制文件到容器中,要复制的文件有:启动脚本和sql文件

COPY install_data.sh /docker-entrypoint-initdb.d/install_data.sh
COPY data.sql /mysql/data.sql

install_data.sh

#!/bin/bash
 mysql -uroot -p$MYSQL_ROOT_PASSWORD <<EOF
 source /mysql/data.sql

data.sql

-- 创建数据库 
DROP database IF EXISTS `docker_database`;
create database `docker_database` default character set utf8 collate utf8_general_ci; 
-- 切换到test_data数据库
use docker_database; 
-- 建表 
DROP TABLE IF EXISTS `person`; 
CREATE TABLE `person` ( 
	`id` bigint(20) NOT NULL, 
	`name` varchar(255) DEFAULT NULL, 
	`age` bigint(20) NOT NULL,
	PRIMARY KEY (`id`) 
) ENGINE=InnoDB DEFAULT CHARSET=latin1; 
-- 插入数据 
INSERT INTO `user` (`id`,`name`,`age` ) 
VALUES 
   (0,'Tom',18);

 

编译、运行

docker image build -t cert_mysql:5.7 .


docker run --network=app --name mysql -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=mariadb cert_mysql:5.7

随笔记录

docker 导出、导入镜像

docker save cert_mysql:5.7 > cert_mysql_5.7.tar


docker load < cert_mysql_5.7.tar

docker 创建 network 

docker network create app

docker 容器连接 network

docker network connect app cert

相关链接

Docker实现MySQL容器启动后自动建库

docker-制作自定义mysql镜像

Docker 网络-端口映射、容器链接、Networking

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值