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

使用如下Dockerfile构建时报错

FROM amd64/mysql:5.7.33COPY mysqld.conf /etc/mysql/mysql.conf.d/mysqld.cnfCOPY mysql.cnf /etc/mysql/conf.d/mysql.cnfCOPY create_tables.sql /docker-entrypoint-initdb.d/create_tables.sqlRUN echo "export LC_ALL='C.UTF-8'" >> /root/.bashrc \&&echo "export LANG='C.UTF-8'" >> /root/.bashrcENV LC_ALL C.UTF-8ENV 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.4COPY mysqld.conf /etc/mysql/mysql.conf.d/mysqld.cnfCOPY mysql.cnf /etc/mysql/conf.d/mysql.cnfCOPY create_tables.sql /docker-entrypoint-initdb.d/create_tables.sqlRUN echo "export LC_ALL='C.UTF-8'" >> /root/.bashrc \&&echo "export LANG='C.UTF-8'" >> /root/.bashrcENV LC_ALL C.UTF-8ENV LANG C.UTF-8ENV LC_ALL C.UTF-8ENV LANG C.UTF-8

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