docker for windows的windows container下mysql的持久化

windows容器模式下的mysql持久化

1、说起来真是头疼,windows容器模式在网上根本一点东西都查不到,下面是自己摸索的一些方法。

关于挂载本地目录映射到容器中,根本不好使,容器一直是意外退出,没办法,只能想别的法子,在Dockerfile上找路子。

FROM steeltoeoss/mysql:latest
MAINTAINER xiyue
WORKDIR C:/MySQL/bin
COPY ./mysql_init.txt C:/ 
ENV Path=C:/Windows/system32;C:/Windows;C:/Windows/System32/Wbem;C:/Windows/System32/WindowsPowerShell/v1.0/;C:/Users/ContainerAdministrator/AppData/Local/Microsoft/WindowsApps;C:/MySQL/bin;
ENV MYSQL=C:/MySQL
VOLUME C:/MySQLDATA
ENTRYPOINT mysqld --init-file=C:/mysql_init.txt --console

这个镜像跟上一篇的差不多,上一篇文章将手动重置root用户的密码,这次我把这些东西写到Dockerfile中了,省一部分事情。

VOLUME是挂载容器卷,这个容器卷在docker中与本地的目录对应,具体对应的哪个目录在下面命令中查看

docker inspect mysqlContainer

2、启动容器后,容器中就有了数据卷,mysql的数据库都是存储在C:/MySQL/data下的,要持久化数据,就把这个目录下的东西复制到数据卷中,要不就直接在mysql设置中,让数据库直接存储在数据卷里。
说白了,都是需要手动去迁移,写一条复制的命令,不会的直接复制这个命令去用

xcopy C:\MySQL\data C:\MySQLDATA
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用Docker和Nacos来配置MySQL持久化。下面是一个简单的步骤指南: 1. 首先,确保你已经安装并配置好了Docker和Nacos。 2. 创建一个MySQLDocker容器,并将其与Nacos进行链接。可以使用以下命令: ``` docker run -d \ --name mysql-container \ -e MYSQL_ROOT_PASSWORD=<root-password> \ -e MYSQL_DATABASE=<database-name> \ -e MYSQL_USER=<username> \ -e MYSQL_PASSWORD=<password> \ -p 3306:3306 \ --network=<nacos-network> \ --restart=always \ mysql:latest ``` 这里需要替换`<root-password>`、`<database-name>`、`<username>`、`<password>`和`<nacos-network>`为你自己的值。 3. 在Nacos中创建一个数据源配置。打开Nacos控制台,进入"配置管理"页面,点击"新建配置"按钮。设置以下参数: - Data ID: `mysql-config` - Group: `DEFAULT_GROUP` - 配置格式:选择`Properties` 在属性值中添加以下内容: ``` spring.datasource.url=jdbc:mysql://mysql-container:3306/<database-name>?characterEncoding=utf8&useSSL=false spring.datasource.username=<username> spring.datasource.password=<password> ``` 这里需要替换`<database-name>`、`<username>`和`<password>`为你之前设置的值。 4. 在你的应用程序中,配置Nacos作为数据源。使用以下示例代码: ```java @SpringBootApplication public class YourApplication { @Value("${spring.datasource.url}") private String datasourceUrl; @Value("${spring.datasource.username}") private String datasourceUsername; @Value("${spring.datasource.password}") private String datasourcePassword; public static void main(String[] args) { SpringApplication.run(YourApplication.class, args); } @Bean public DataSource dataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setUrl(datasourceUrl); dataSource.setUsername(datasourceUsername); dataSource.setPassword(datasourcePassword); return dataSource; } } ``` 这里的`@Value`注解用于从Nacos配置中获取属性值。 5. 最后,启动你的应用程序,并检查MySQL持久化是否成功。 这就是使用Docker和Nacos配置MySQL持久化的简单步骤。希望对你有帮助!如果有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值