Ubuntu安装MySQL步骤及注意事项

一、安装前准备

        1. 系统更新:在安装 MySQL 之前,确保你的 Ubuntu 系统软件包是最新的,这能避免因软件包版本问题导致的安装错误,并获取最新的安全补丁。打开终端,执行以下两条命令:

sudo apt update
sudo apt upgrade -y

        sudo apt update命令用于更新软件包索引,让系统知晓可用软件包的最新版本信息。sudo apt upgrade -y则会自动安装系统中已安装软件包的可用更新,-y参数表示自动回答 “是”,避免逐个确认的麻烦。

        2. 检查是否已安装 MySQL:有些情况下,系统可能已经预装了 MySQL 或者之前安装过残留文件。通过以下命令检查:

dpkg -l | grep mysql

        如果有相关软件包列出,可能需要先卸载。例如,若要卸载mysql-server,可执行:

sudo apt - get remove mysql - server

        若要彻底清除包括配置文件在内的所有内容,使用:

sudo apt - get purge mysql - server

        卸载后,还需手动删除可能残留的相关目录,如/etc/mysql和/var/lib/mysql等(操作时需谨慎,确认无重要数据留存)。

二、安装 MySQL

        1.使用 Ubuntu 官方仓库安装

sudo apt install -y mysql - server

        该命令会从 Ubuntu 官方软件源下载并安装 MySQL 服务器及其依赖项。安装过程中,系统会提示设置root用户的密码。请设置一个强密码,包含字母(大小写)、数字和特殊字符,以增强安全性。例如:MyS3cur3P@ssw0rd!

sudo apt install -y libmysqlclient - dev
  • 安装 MySQL 服务器软件包:在终端执行以下命令:
  • 安装 MySQL 开发包(可选):若你计划进行 MySQL 相关开发工作,还需安装开发包,它包含用于开发的头文件和动态库文件。执行:

        2.使用 MySQL 官方仓库安装(获取最新版本)

sudo apt update

然后安装 MySQL 服务器:

sudo apt install -y mysql - server
  • 下载并添加 MySQL APT 仓库
wget https://dev.mysql.com/get/mysql - apt - config_0.8.26 - 1_all.deb
sudo dpkg -i mysql - apt - config_0.8.26 - 1_all.deb

安装过程中,会弹出一个配置界面,可根据需求选择要安装的 MySQL 版本系列(如 MySQL 8.0、MySQL 5.7 等)以及其他相关选项,一般保持默认即可。

  • 首先,访问MySQL APT Repository 页面,找到最新版本的mysql - apt - config包下载链接。例如,当前最新版本为mysql - apt - config_0.8.26 - 1_all.deb,使用wget命令下载:
  • 下载完成后,安装该配置包:
  • 更新 APT 仓库并安装 MySQL 服务器:添加完 MySQL 官方仓库后,更新系统软件包索引:

三、启动与配置 MySQL 服务

        1.启动 MySQL 服务:安装完成后,MySQL 服务默认自动启动。但如果安装后未自动启动,或者你手动停止了服务,可通过以下命令启动:

sudo systemctl start mysql

        2.设置开机自启:为确保系统每次启动时 MySQL 服务都能自动运行,执行:

sudo systemctl enable mysql

        3.检查服务状态:使用以下命令查看 MySQL 服务是否正常运行:

sudo systemctl status mysql

        若服务正常运行,输出中会显示Active: active (running)等字样。例如:

● mysql.service - MySQL Community Server
Loaded: loaded (/lib/systemd/system/mysql.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2025 - 04 - 18 10:30:00 UTC; 1min ago
Main PID: 1234 (mysqld)
Status: "Server is operational"
Tasks: 38 (limit: 4687)
Memory: 200.0M
CGroup: /system.slice/mysql.service
└─1234 /usr/sbin/mysqld

四、MySQL 初始设置与安全加固

  1. 处理初始自动生成的用户名和密码(部分版本适用):在某些最新版本的 MySQL 安装过程中,系统会自动为root用户生成一个临时密码。需找到该临时密码并进行更改。
sudo grep 'temporary password' /var/log/mysql/error.log

输出类似如下:

(2025 - 04 - 18T10:30:00.123456Z) (Note) A temporary password is generated for root@localhost: xXxXxXxXxXx

记下该临时密码(例如xXxXxXxXxXx)。

sudo mysql_secure_installation

执行该脚本后,会被提示执行以下操作:

  • 查找临时密码:安装完成后,MySQL 会将临时密码记录在日志文件中。使用以下命令查看日志并获取临时密码:
  • 运行安全性脚本:为提高 MySQL 的安全性,并修改初始密码,建议运行官方提供的安全性脚本:
  • 输入当前root密码:使用上一步骤中获取的临时密码。
  • 设置新root密码:根据提示设置一个强密码,例如包含大写字母、小写字母、数字和特殊字符的组合,如MyNewP@ss123!。
  • 移除匿名用户:建议选择移除,以提高安全性。
  • 禁止远程root登录:建议禁止,减少安全风险。
  • 移除测试数据库:建议移除,避免不必要的安全隐患。
  • 重新加载权限表:选择 “是” 以应用更改。

        2. 手动修改root初始密码:如果不想使用mysql_secure_installation脚本,也可手动修改root密码。

sudo mysql -u root -p
ALTER USER 'root'@'localhost' IDENTIFIED BY 'YourNewStrongPassword!';
FLUSH PRIVILEGES;

将YourNewStrongPassword!替换为你希望设置的新密码。

sudo mysql -u root -p

输入新密码后,应能成功登录。

  • 登录 MySQL:使用当前root密码(如果是新安装且未设置过密码,可能为空或使用临时密码)登录 MySQL:
  • 修改root密码:在 MySQL 命令行中执行以下命令以修改root用户的密码:
  • 验证密码修改:退出 MySQL 并重新登录以验证新密码是否生效:

五、验证安装

  1. 登录 MySQL:使用设置好的root密码登录 MySQL:
mysql -u root -p

输入密码后,若成功登录,会进入 MySQL 命令行界面,显示类似如下提示符:

mysql>

        2.检查 MySQL 版本:在 MySQL 命令行中运行以下命令查看版本信息:

SELECT VERSION();

输出结果类似:

+-----------+
| VERSION() |
+-----------+
| 8.0.33 |
+-----------+

这表明 MySQL 已成功安装并运行。

六、配置防火墙(可选)

如果你的 Ubuntu 系统启用了防火墙,且需要通过网络访问 MySQL,确保防火墙允许 MySQL 服务的端口(默认为 3306)的流量。

  1. 使用 UFW 防火墙
sudo ufw allow 'MySQL'

或者更具体地允许 3306 端口的 TCP 流量:

sudo ufw allow 3306/tcp
sudo ufw reload
  • 允许 MySQL 服务通过防火墙:执行以下命令:
  • 重新加载防火墙规则:使设置生效:

        2.使用其他防火墙(如 iptables):具体配置命令因防火墙规则管理方式而异。例如,使用iptables允许 3306 端口的 TCP 流量:

sudo iptables -A INPUT -p tcp -m tcp --dport 3306 -j ACCEPT

        同时,可能需要保存iptables规则,以便系统重启后仍然生效。不同系统保存iptables规则的方式略有不同,例如在某些系统中可使用iptables - save > /etc/iptables/rules.v4命令保存规则。

七、注意事项

  1. 字符集设置:MySQL 默认字符集可能不符合需求,尤其是在处理包含非 ASCII 字符(如中文、日文等)的数据时。建议在安装完成后,修改 MySQL 配置文件(通常位于/etc/mysql/mysql.conf.d/mysqld.cnf)来设置合适的字符集。例如,在文件中添加或修改以下内容:

[mysqld]

character - set - server = utf8mb4

collation - server = utf8mb4_unicode_ci

然后重启 MySQL 服务使设置生效:

sudo systemctl restart mysql

        注意,要先设置字符集再创建数据库和导入数据,否则数据库的字符集不会根据默认字符集改变而改变。

        2.远程访问设置:默认情况下,MySQL 只允许本地访问。如果需要从远程主机访问 MySQL,除了配置防火墙允许 3306 端口流量外,还需修改 MySQL 的配置文件。在/etc/mysql/mysql.conf.d/mysqld.cnf文件中,找到并注释掉或修改bind - address这一行,将其值改为0.0.0.0,表示允许来自任何 IP 地址的连接(生产环境中应谨慎设置,建议只允许受信任的 IP 地址连接):

#bind - address = 127.0.0.1
bind - address = 0.0.0.0

        然后重启 MySQL 服务。此外,还需在 MySQL 中为远程访问用户授权,例如创建一个新用户并授予其远程访问权限:

CREATE USER 'new_user'@'%' IDENTIFIED BY 'new_password';
GRANT ALL PRIVILEGES ON *.* TO 'new_user'@'%';
FLUSH PRIVILEGES;

这里new_user为新用户名,new_password为密码,%表示允许从任何主机连接。

        3.备份与恢复:定期备份 MySQL 数据库至关重要,以防止数据丢失。可使用mysqldump命令进行数据库备份。例如,备份整个数据库:

mysqldump -u root -p your_database > backup.sql

其中your_database为要备份的数据库名称,backup.sql为备份文件名称。恢复备份时,可使用以下命令:

mysql -u root -p your_database < backup.sql

        4.软件包更新与兼容性:定期更新 MySQL 软件包以获取最新功能和安全补丁。但在更新前,务必做好数据备份,并在测试环境中先进行更新测试,确保新版本与现有应用程序兼容,避免因软件包更新导致系统或应用程序出现问题。

        通过以上步骤和注意事项,你应该能够顺利在 Ubuntu 系统上安装、配置和使用 MySQL 数据库,并保障其安全性和稳定性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902369.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【愚公系列】《Python网络爬虫从入门到精通》054-Scrapy 文件下载

&#x1f31f;【技术大咖愚公搬代码&#xff1a;全栈专家的成长之路&#xff0c;你关注的宝藏博主在这里&#xff01;】&#x1f31f; &#x1f4e3;开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主&#xff01; &#x1f…

2025最新︱中国信通院静态应用程序安全测试(SAST)工具能力评估,悬镜安全灵脉AI通过评估!

背景 研发运营安全&#xff08;DevSecOps&#xff09;从研发运营&#xff08;DevOps&#xff09;的概念延伸和演变而来&#xff0c;其核心理念是将安全贯穿从开发到运营的软件开发生命周期的每一个环节&#xff0c;在每个阶段自动实施安全措施&#xff0c;从而实现快速开发交付…

辛格迪客户案例 | 浙江高跖医药委托生产质量管理协同(OWL MAH)项目

一、案例概述 浙江高跖医药科技股份有限公司是一家集“研、产、销”为一体的专业化药品持证企业。高跖医药自成立之初就建立并运行着一套相对完善的质量管理体系&#xff0c;涵盖了药品的研发、生产监管及销售。高跖医药于2022年选择实施了辛格迪的“委托生产质量管理协同解决…

【NLP 65、实践 ⑯ 基于Agent优化文章】

羁绊由我而起&#xff0c;痛苦也由我承担 —— 25.4.18 一、⭐【核心函数】定义大模型调用函数 call_large_model prompt&#xff1a;用户传入的提示词&#xff08;如 “请分析这篇作文的主题”&#xff09;&#xff0c;指导模型执行任务 client&#xff1a;Zhipu…

【锂电池SOH估计】BP神经网络锂电池健康状态估计,锂电池SOH估计(Matlab完整源码和数据)

目录 效果一览程序获取程序内容研究内容基于BP神经网络的锂电池健康状态估计研究摘要关键词1. 引言1.1 研究背景1.2 研究意义1.3 研究目标2. 文献综述2.1 锂电池SOH估计理论基础2.2 传统SOH估计方法2.3 基于BP神经网络的SOH估计研究进展2.4 研究空白与创新点3. BP神经网络原理3…

2025第十六届蓝桥杯python B组满分题解(详细)

目录 前言 A: 攻击次数 解题思路&#xff1a; 代码&#xff1a; B: 最长字符串 解题思路&#xff1a; 代码&#xff1a; C: LQ图形 解题思路&#xff1a; 代码&#xff1a; D: 最多次数 解题思路&#xff1a; 代码&#xff1a; E: A * B Problem 解题思路&…

第十二节:原理深挖-React Fiber架构核心思想

链表结构、时间切片&#xff08;Time Slicing&#xff09; 优先级调度实现&#xff08;如用户输入>网络请求&#xff09; React Fiber架构深度解析&#xff1a;从链表到优先级调度的革命性升级 一、Fiber架构核心设计思想 React Fiber是React 16的底层协调算法重构&#x…

你学会了些什么211201?--http基础知识

概念 HTTP–Hyper Text Transfer Protocol&#xff0c;超文本传输协议&#xff1b;是一种建立在TCP上的无状态连接&#xff08;短连接&#xff09;。 整个基本的工作流程是&#xff1a;客户端发送一个HTTP请求&#xff08;Request &#xff09;&#xff0c;这个请求说明了客户端…

MCU开发学习记录8 - 基本定时器学习与实践(HAL库) - 定时器DMA循环模式修改ARR值、定时器中断方式修改ARR值 - STM32CubeMX

名词解释&#xff1a; TRGO&#xff1a;Trigger Out General Purpose Output ARR&#xff1a;Auto-reload PSC&#xff1a;Prescaler CNT&#xff1a;Counter EGR&#xff1a;event generation register 本文将介绍基本定时器的概念、相关函数以及STM32CubeMX生成定时器的配置…

考研系列-计算机网络冲刺考点汇总(上)

写在前面 本文将总结王道408考研课程的计算机网络冲刺考点的第一章到第三章内容&#xff08;计算机网络体系结构、物理层、数据链路层&#xff09;。【图片较多&#xff0c;加载需要时间&#xff0c;可以提前打开加载~~】 第一章、计算机网络体系结构 注意&#xff1a;PCI(头部…

设计模式每日硬核训练 Day 14:组合模式(Composite Pattern)完整讲解与实战应用

&#x1f504; 回顾 Day 13&#xff1a;桥接模式小结 在 Day 13 中&#xff0c;我们学习了桥接模式&#xff08;Bridge Pattern&#xff09;&#xff1a; 用于将“抽象”与“实现”分离&#xff0c;适用于双维度变化场景&#xff08;如图形类型 渲染方式&#xff09;。它强调…

讯联桌面TV版apk下载-讯联桌面安卓电视版免费下载安装教程

在智能电视的使用过程中&#xff0c;一款好用的桌面应用能极大提升我们的使用体验。讯联桌面 TV 版就是这样一款备受关注的应用&#xff0c;它可以让安卓电视拥有更个性化、便捷的操作界面。今天&#xff0c;就为大家详细介绍讯联桌面 TV 版 apk 的免费下载安装教程。 一、下载…

Nginx知识点

Nginx发展历史 Nginx 是由俄罗斯程序员 Igor Sysoev 开发的高性能开源 Web 服务器、反向代理服务器和负载均衡器 &#xff0c;其历史如下&#xff1a; 起源与早期开发&#xff08;2002 - 2004 年&#xff09; 2002 年&#xff0c;当时 Igor Sysoev 在为俄罗斯门户网站 Rambl…

uview1.0 tabs组件放到u-popup中在微信小程序中滑块样式错乱

解决思路 重新计算布局信息&#xff1a;在弹窗显示后重新调用 init 方法来计算组件的布局信息。使用 nextTick&#xff1a;保证在视图更新之后再进行布局信息的计算。 <u-tabs ref"tabsRef" ></u-tabs> makeClick(){this.makeShowtruethis.$nextTick…

腾讯一面-软件开发实习-PC客户端开发方向

1.自我介绍就不多赘述了 2. 请介绍一下你的项目经历 - 介绍了专辑鉴赏项目&#xff0c;前端使用html语言编写&#xff0c;后端基于http协议使用C语言进行网页开发。此外&#xff0c;还提及项目中涉及处理多线程问题以及做过内存池管理项目。 3. 项目中HTTP协议是使用库实现的…

[数据可视化] Datagear使用心得:从数据整备到可视化联动实践

Datagear 是一款功能强大的数据可视化与报表工具&#xff0c;在日常数据分析与展示过程中&#xff0c;能有效帮助用户构建交互式报表与面板。本文结合实际使用场景&#xff0c;总结了在 Datagear 平台上关于元数据整备、Board 面板设计、图表嵌入等方面的使用经验&#xff0c;供…

【音视频】MP4解封装

一、概述 实现了读取mp4文件&#xff0c;提取出h264和aac文件&#xff0c;可以直接播放 二、实现过程 准备文件 在build路径下添加mp4文件 同时&#xff0c;添加main函数参数&#xff0c;表示输入文件和输出文件 打开文件 打开输入文件&#xff0c;初始化格式上下文 char…

idea2024.1双击快捷方式打不开

idea2024.1突然双击快捷方式打不开&#xff0c;使用管理员运行也打不开 在安装的idea路径下的bin目录下双击打开idea.bat文件&#xff0c;要是打不开使用txt格式打开&#xff0c;打开后在最后一行加上pause&#xff0c;之后保存。 看看报错信息是不是有一个initializedExcept…

【错误记录】Windows 命令行程序循环暂停问题分析 ( 设置 “ 命令记录 “ 选项 | 启用 “ 丢弃旧的副本 “ 选项 | 将日志重定向到文件 )

文章目录 一、报错信息二、问题分析1、Windows 命令行的缓冲区机制2、命令记录设置 三、解决方案1、设置 " 命令记录 " 选项2、将日志重定向到文件 一、报错信息 Java 程序中 , 设置 无限循环 , 每次循环 休眠 10 秒后 , 再执行程序逻辑 , 在命令行中打印日志信息 ; …

STM32H5开发陀螺仪LSM6DSV16X(1)----轮询获取陀螺仪数据

STM32H5开发陀螺仪LSM6DSV16X.1--轮询获取陀螺仪数据 概述视频教学样品申请源码下载硬件准备参考程序通信模式管脚定义IIC通信模式速率新建工程工程模板保存工程路径芯片配置工程模板选择时钟设置UART配置UART属性配置设置e2studio堆栈e2studio的重定向printf设置R_SCI_UART_Op…