MySQL 安装与配置指南

ops/2024/10/9 15:17:19/

MySQL 是一种广泛使用的关系型数据库管理系统,为各种应用程序提供高效的数据存储和管理解决方案。本文将介绍如何在不同的操作系统中安装 MySQL,以及如何进行基本的配置,以确保数据库系统的最佳性能和稳定性。

一、环境准备

1.1 系统要求

在安装 MySQL 之前,确保您的系统满足以下最低要求:

  • 处理器:支持 x86_64 或 ARM 架构的 CPU。
  • 内存:至少 512MB RAM,建议 1GB 以上。
  • 硬盘空间:至少 500MB 可用空间,用于安装 MySQL 服务器和数据库文件。

具体的系统要求可能因 MySQL 版本和预期负载的不同而有所变化。在生产环境中,建议根据应用需求合理配置系统资源。

1.2 常见操作系统支持

MySQL 支持多种主流操作系统,包括但不限于:

  • Windows:支持 Windows 10 及更高版本,Windows Server 2012 及以上版本。
  • Linux:支持 Ubuntu、CentOS、Debian、Red Hat、Fedora 等发行版。
  • macOS:支持 macOS 10.13 及更高版本。
  • Docker:可以通过 Docker 容器快速部署 MySQL。

根据您的操作系统选择合适的安装方式,下面我们将详细介绍各个系统的安装步骤。

二、MySQL 安装

2.1 Windows 安装

1. 下载 MySQL Installer

首先,从 MySQL 官方网站下载 MySQL Installer for Windows。MySQL Installer 提供了图形化的安装界面,方便用户快速安装 MySQL 及相关工具。

2. 安装 MySQL
  1. 运行下载的安装程序,选择 CustomFull 安装类型,Full 安装包括所有组件,而 Custom 可以让你选择需要的组件。
  2. 在安装过程中,您可以选择安装 MySQL Server、MySQL Workbench、MySQL Shell 等组件。
  3. 在配置步骤中,设置 root 用户密码,并根据需求创建新的用户。
  4. 选择数据库存储引擎,通常选择 InnoDB。
  5. 配置 MySQL 为 Windows 服务,以便系统启动时自动运行。

安装完成后,您可以通过 MySQL Workbench 连接和管理数据库

2.2 Linux 安装

1. 使用 APT 或 YUM 安装

在 Linux 上安装 MySQL 可以通过系统的包管理器来完成。以 Ubuntu 和 CentOS 为例:

  • Ubuntu/Debian
sudo apt update
sudo apt install mysql-server
  • CentOS/RHEL
sudo yum update
sudo yum install mysql-server
2. 初始化数据库

安装完成后,使用以下命令初始化 MySQL 数据库

sudo mysql_secure_installation

该命令将引导您设置 root 密码、移除匿名用户、禁用远程 root 登录以及删除测试数据库,以提高数据库安全性。

2.3 macOS 安装

1. 使用 Homebrew 安装

在 macOS 上,您可以使用 Homebrew 轻松安装 MySQL:

brew update
brew install mysql
2. 启动 MySQL

安装完成后,使用以下命令启动 MySQL 服务:

brew services start mysql

您也可以通过以下命令停止 MySQL 服务:

brew services stop mysql

2.4 Docker 中的 MySQL

如果您更倾向于使用容器化方式部署 MySQL,可以通过 Docker 快速启动 MySQL 容器。

1. 拉取 MySQL 镜像

首先,从 Docker Hub 拉取最新的 MySQL 镜像:

docker pull mysql:latest
2. 启动 MySQL 容器

使用以下命令启动 MySQL 容器:

docker run --name mysql-container -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:latest

这将启动一个 MySQL 容器,并设置 root 用户密码为 my-secret-pw

3. 连接 MySQL 容器

您可以使用以下命令进入 MySQL 容器并连接到 MySQL 实例:

docker exec -it mysql-container mysql -uroot -p

三、配置 MySQL

3.1 MySQL 配置文件

MySQL 的主要配置文件为 my.cnfmy.ini,该文件包含了 MySQL 服务器的所有配置选项。配置文件的位置因操作系统而异:

  • Linux:通常位于 /etc/mysql/my.cnf/etc/my.cnf
  • Windows:通常位于 C:\ProgramData\MySQL\MySQL Server X.Y\my.ini
  • macOS:通常位于 /usr/local/etc/my.cnf

3.2 常用配置选项详解

以下是一些常见的配置选项,您可以根据系统需求进行调整:

  • bind-address:用于指定 MySQL 服务器监听的 IP 地址,默认情况下是 127.0.0.1,如果需要远程连接,可以设置为 0.0.0.0
  • max_connections:设置 MySQL 允许的最大并发连接数,默认值为 151,您可以根据服务器性能和应用需求调整该值。
  • innodb_buffer_pool_size:用于设置 InnoDB 缓冲池的大小,推荐将其设置为系统总内存的 50%-75%。
  • log_error:指定错误日志文件的位置,便于排查问题。
  • slow_query_log:启用慢查询日志,记录执行时间超过指定阈值的查询,默认阈值为 10 秒。

3.3 设置字符集与排序规则

为了避免字符编码问题,建议将 MySQL 的默认字符集设置为 utf8mb4,并使用 utf8mb4_unicode_ci 作为默认排序规则:

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci[client]
default-character-set=utf8mb4

此配置确保 MySQL 在存储和检索数据时支持多种语言字符集,并且能够正确处理 Emoji 等多字节字符。

四、启动与关闭 MySQL

4.1 Windows 服务管理

在 Windows 上安装 MySQL 时,您可以将其作为 Windows 服务管理。以下是一些常用的服务管理命令:

  • 启动 MySQL 服务
net start mysql
  • 停止 MySQL 服务
net stop mysql
  • 重启 MySQL 服务
net stop mysql && net start mysql

4.2 Linux 系统服务管理

在 Linux 系统中,MySQL 通常作为系统服务管理。以下是一些常用的系统服务管理命令:

  • 启动 MySQL
sudo systemctl start mysql
  • 停止 MySQL
sudo systemctl stop mysql
  • 重启 MySQL
sudo systemctl restart mysql
  • 查看 MySQL 服务状态
sudo systemctl status mysql

4.3 使用命令行启动和关闭

除了使用服务管理工具,您也可以直接通过命令行启动或关闭 MySQL:

  • 启动 MySQL
mysqld_safe &
  • 关闭 MySQL
mysqladmin -u root -p shutdown

这种方式在调试或临时管理 MySQL 时非常有用。

五、总结

MySQL 的安装与配置并不复杂,本文详细介绍了如何在不同操作系统中安装 MySQL,以及如何进行基本配置。通过合理的配置,您可以确保 MySQL 在各种环境中高效、稳定地运行。无论是在 Windows、Linux、macOS 还是 Docker 中,掌握这些基本操作将帮助您更好地管理和维护 MySQL 数据库系统。


http://www.ppmy.cn/ops/95089.html

相关文章

Android持久化技术—文件存储

Android持久化技术—文件存储 文件存储是Android中最基本的一种数据存储方式,它不对存储的内容进行任何的格式化处理,所有数据都是原封不动地保存到文件当中的,因而它比较适合用于存储一些简单的文本数据或二进制数据。如果你想使用文件存储…

Datawhale X 魔搭 AI夏令营第四期魔搭-AIGC文生图方向Task3笔记

Task3:进阶上分-实战优化 part1:工具初探一ComfyUI应用场景探索 ComfyUI概述 ComfyUI是一个功能强大、高度模块化的Stable Diffusion图形用户界面和后端系统,它允许用户通过链接不同的节点来构建复杂的图像生成工作流程。这些节点可以包括各…

npm 使用淘宝镜像,安装pnpm

(安装nodejs时,会自动安装npm)使用 npm 安装包时,需要去 npm 仓库获取,而 npm 仓库在国外,很不稳定,有时获取会失败。淘宝搭建了一个国内npm服务器,会定时拉取国外npm仓库内容&#…

井字棋游戏(HTML+CSS+JavaScript)

🌏个人博客主页:心.c 前言:这两天在写植物大战僵尸,写不动了,现在和大家分享一下之前我写的一个很简单的小游戏井字棋,这个没有AI,可以两个人一起玩,如果大家觉得我哪里写的有一些问…

【大模型部署及其应用 】使用 Llama 3 开源和 Elastic 构建 RAG

使用 Llama 3 开源和 Elastic 构建 RAG 本博客将介绍使用两种方法实现 RAG。 Elastic、Llamaindex、Llama 3(8B)版本使用 Ollama 在本地运行。 Elastic、Langchain、ELSER v2、Llama 3(8B)版本使用 Ollama 在本地运行。 笔记本可从此GitHub位置获取。 在开始之前,让我…

LVS 、DR模式

lvs --环境 主机名IP地址功能web1192.168.1.17 rs web2192.168.1.18realservenat 内:192.168.1.16 外:192.168.1.102 directorserver,ntpdns192.168.1.12dns --web1、web2 yum -y install nginxecho "xx" > /usr/share/nginx/html/index.…

Android12 SystemUI QS面板新增截屏功能

问题:Android12 中SystemUI版本,QS下拉快捷面板式没有截屏功能的。 需求:客户要求在项目中实现下拉快捷面板具备一键截屏功能 目前自己只针对Android12 mtk/RK平台实践过,接触的全志平台暂未实验验证。 文章目录 前言一、实际实现效果二、修改点1.新增文件2.修改文件三、基…

2024爱分析·AI Agent开发管理平台市场厂商评估报告:火山引擎

01研究范围定义 大模型浪潮席卷全球,AI Agent作为这股浪潮中的新星正在取代Copilot,成为大模型应用的主流形态之一,以其惊人的速度和影响力重塑科技和商业的版图。 AI Agent是指以大模型为驱动,具有自主理解感知、规划、记忆和使…