脚本安装mysql docker
时间: 2023-11-07 09:01:53 浏览: 59
脚本安装MySQL Docker非常简单。你只需要执行以下命令即可:
```
docker run -p 3306:3306 --name hrun_mysql -v ~/mysql/conf:/etc/mysql/conf.d -v ~/mysql/data:/var/lib/mysql -v ~/mysql/logs:/logs -e MYSQL_ROOT_PASSWORD=xxxx -d mysql:5.7
```
这个命令会在Docker中运行一个MySQL 5.7的容器,并将容器的3306端口映射到主机的3306端口。同时,它会创建并挂载一些目录用于存储MySQL的配置文件、数据和日志。你需要将`xxxx`替换为你想要设置的MySQL root密码。
相关问题
mysql docker启动脚本
回答: 如果你想在启动MySQL Docker容器时执行一些初始化的SQL脚本,可以通过在容器启动时挂载一个包含脚本的目录,并在Dockerfile中使用ENTRYPOINT命令来指定执行脚本的命令。
首先,确保你已经安装了Docker和Docker Compose。如果你使用的是Docker Desktop,那么你不需要额外安装Docker Compose。然后,你可以从GitHub上下载对应版本的Docker Compose。
接下来,你需要选择MySQL版本为8.0的Docker镜像。你可以使用以下命令来启动一个MySQL容器,并指定root用户的密码和创建的数据库名:
```
docker run -d --name mysql-container -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -e MYSQL_DATABASE=admin mysql:8.0
```
这样会创建一个名为admin的数据库,但是它是一个空的数据库。如果你想在容器启动时自动执行指定的SQL脚本,你可以将这些脚本放在一个目录中,并将该目录挂载到容器中。例如,你可以将脚本放在一个名为`init-scripts`的目录中。
然后,你可以使用以下的Docker Compose文件来定义你的MySQL容器,并在该文件中指定挂载的目录和执行脚本的命令:
```yaml
version: '3'
services:
mysql:
image: mysql:8.0
ports:
- 3306:3306
environment:
MYSQL_ROOT_PASSWORD: root
MYSQL_DATABASE: admin
volumes:
- ./init-scripts:/docker-entrypoint-initdb.d
```
在这个例子中,我们将`./init-scripts`目录挂载到容器的`/docker-entrypoint-initdb.d`目录中,这是MySQL官方镜像中用于执行初始化脚本的目录。你可以将你的初始化SQL脚本放在`./init-scripts`目录中,并在容器启动时自动执行。
希望这能帮到你。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [docker容器启动Mysql执行初始化sql脚本实现](https://blog.csdn.net/Allocator/article/details/117092356)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"]
- *3* [Docker(五)、启动mysql时自动执行脚本](https://blog.csdn.net/qq_32923745/article/details/80817477)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
linux docker 安装mysql
在Linux下使用Docker安装MySQL有多种方法。以下是三种常见的方法:
方法一:使用docker run命令拉取并运行MySQL容器。例如,可以使用以下命令拉取并运行MySQL 5.7容器:
```
docker run -d -p 3306:3306 --name mysql5.7 -e MYSQL_ROOT_PASSWORD="strongpassword" docker.io/mysql:5.7
```
这个命令会在后台运行一个MySQL 5.7容器,并将主机的3306端口映射到容器的3306端口。同时,通过`-e MYSQL_ROOT_PASSWORD`参数设置了MySQL的root用户密码为"strongpassword"。\[1\]
方法二:使用docker run命令执行安装脚本。例如,可以使用以下命令执行安装脚本并运行MySQL 5.7容器:
```
docker run -d --privileged=true --name mysql57 -p 5508:3306 --restart=always -v /usr/local/docker/mysql/data:/var/lib/mysql -v /usr/local/docker/mysql/config/my.cnf:/etc/mysql/my.cnf -e MYSQL_ROOT_PASSWORD=root mysql:5.7
```
这个命令会在后台运行一个MySQL 5.7容器,并将主机的5508端口映射到容器的3306端口。同时,通过`-v`参数指定了数据存储位置和配置文件位置,通过`-e MYSQL_ROOT_PASSWORD`参数设置了MySQL的root用户密码为"root"。\[2\]
方法三:使用docker pull命令拉取MySQL镜像,然后使用docker run命令创建并运行MySQL容器。例如,可以使用以下命令拉取MySQL 5.7镜像:
```
docker pull mysql:5.7
```
然后,可以使用以下命令创建并运行MySQL容器:
```
docker run -p 3306:3306 --name myMysql -v /usr/local/workspace/mysql/conf:/etc/mysql -v /usr/local/workspace/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
```
这个命令会在后台运行一个MySQL 5.7容器,并将主机的3306端口映射到容器的3306端口。同时,通过`-v`参数指定了数据存储位置和配置文件位置,通过`-e MYSQL_ROOT_PASSWORD`参数设置了MySQL的root用户密码为"123456"。\[3\]
无论使用哪种方法,安装完成后,您可以使用Navicat等工具连接到MySQL数据库进行操作。如果在连接时遇到错误,可能需要开启远程访问权限。您可以通过进入MySQL容器并执行一些命令来开启远程访问权限。具体的解决方案可以参考上述引用\[3\]中的内容。
#### 引用[.reference_title]
- *1* [在Linux系统中用Docker安装mysql](https://blog.csdn.net/weixin_56306210/article/details/126094938)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [【linux安装docker】使用docker安装mysql](https://blog.csdn.net/qq_40179653/article/details/124906857)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *3* [Linux下docker安装Mysql](https://blog.csdn.net/weixin_44470298/article/details/107975462)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]