[docker]-构建arm架构的mariadb镜像并运行

导语:公司需要在arm服务器上使用docker部署服务。第一次构建镜像,mysql这块踩了不少坑,记录一下。

使用如下Dockerfile构建时报错

FROM amd64/mysql:5.7.33
COPY mysqld.conf /etc/mysql/mysql.conf.d/mysqld.cnf
COPY mysql.cnf /etc/mysql/conf.d/mysql.cnf
COPY create_tables.sql /docker-entrypoint-initdb.d/create_tables.sql
RUN echo "export LC_ALL='C.UTF-8'" >> /root/.bashrc 
&&  echo "export LANG='C.UTF-8'" >> /root/.bashrc

ENV LC_ALL C.UTF-8
ENV LANG C.UTF-8

因为镜像不是arm的一直报错,用了百度的方法 --platform=linux/amd64依旧不行。

查看mysql镜像,发现支持arm64的镜像没有5.7的。查了mariadb,发现5.7版本正好对应mariadb的10.4版本,mariadb有arm64的10.4版本

采用mariadb代替mysql5.7进行构建

FROM arm64v8/mariadb:10.4
COPY mysqld.conf /etc/mysql/mysql.conf.d/mysqld.cnf
COPY mysql.cnf /etc/mysql/conf.d/mysql.cnf
COPY create_tables.sql /docker-entrypoint-initdb.d/create_tables.sql
RUN echo "export LC_ALL='C.UTF-8'" >> /root/.bashrc 
&&  echo "export LANG='C.UTF-8'" >> /root/.bashrc

ENV LC_ALL C.UTF-8
ENV LANG C.UTF-8
ENV LC_ALL C.UTF-8
ENV LANG C.UTF-8

构建之后成功在arm机器上启动

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>