当前位置: 首页 > article >正文

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 数据库,并保障其安全性和稳定性。

相关文章:

Ubuntu安装MySQL步骤及注意事项

一、安装前准备 1. 系统更新&#xff1a;在安装 MySQL 之前&#xff0c;确保你的 Ubuntu 系统软件包是最新的&#xff0c;这能避免因软件包版本问题导致的安装错误&#xff0c;并获取最新的安全补丁。打开终端&#xff0c;执行以下两条命令&#xff1a; sudo apt update sudo …...

【网络篇】从零写UDP客户端/服务器:回显程序源码解析

大家好呀 我是浪前 今天讲解的是网络篇的第四章&#xff1a;从零写UDP客户端/服务器&#xff1a;回显程序源码解析 从零写UDP客户端/服务器&#xff1a;回显程序源码解析 UDP 协议特性​核心类介绍​ UDP的socket应该如何使用&#xff1a;1: DatagramSocket2: DatagramPacket回…...

MATLAB 控制系统设计与仿真 - 38

多变量系统控制器设计实例1 考虑如下给出的多变量系统模型&#xff1a; 考虑混合灵敏度问题&#xff0c;引入加权矩阵&#xff1a; 设计鲁棒控制器&#xff0c;并绘制闭环系统的阶跃响应曲线及开环系统的奇异值曲线。 MATLAB代码如下&#xff1a; clear all;clc; stf(s); g1…...

轻量化高精度的视频语义分割

Video semantic segmentation (VSS)视频语义分割 Compact Models(紧凑模型) 在深度学习中,相对于传统模型具有更小尺寸和更少参数数量的模型。这些模型的设计旨在在保持合理性能的同时,减少模型的计算和存储成本。 紧凑模型的设计可以涉及以下一些技术: 深度剪枝(Deep…...

Spring Boot 版本与对应 JDK 版本兼容性

Spring Boot 版本与对应 JDK 版本兼容性 以下是 Spring Boot 主要版本与所需 JDK 版本的对应关系&#xff0c;以及长期支持(LTS)信息&#xff1a; 最新版本对应关系 (截至2024年) Spring Boot 版本发布日期支持的 JDK 版本备注3.2.x (最新)2023-11JDK 17-21推荐使用 JDK 173…...

[密码学实战]详解gmssl库与第三方工具兼容性问题及解决方案

[密码学实战]详解gmssl库与第三方工具兼容性问题及解决方案 引言 国密算法&#xff08;SM2/SM3/SM4&#xff09;在金融、政务等领域广泛应用&#xff0c;但开发者在集成gmssl库实现SM2签名时&#xff0c;常遇到与第三方工具&#xff08;如OpenSSL、国密网关&#xff09;验证不…...

JavaScript模块化开发:CommonJS、AMD到ES模块

引言 在Web开发的早期阶段&#xff0c;JavaScript代码通常被编写在一个庞大的文件中或分散在多个脚本标签里&#xff0c;这种方式导致了全局变量污染、依赖关系难以管理、代码复用困难等问题。随着Web应用日益复杂&#xff0c;模块化编程成为了解决这些问题的关键。本文将带您…...

【k8s系列1】一主两从结构的环境准备

环境准备 虚拟机软件准备及安装&#xff0c;这里就不详细展开了&#xff0c;可以看文章:【一、虚拟机vmware安装】 linux环境准备及下载&#xff0c;下载镜像centOS7.9&#xff0c;以前也有写过这个步骤的文章&#xff0c;可以看&#xff1a;【二、安装centOS】 开始进入正题…...

dubbo SPI插件扩展点使用

参考&#xff1a;SPI插件扩展点 Dubbo SPI概述 使用IoC容器帮助管理组件的生命周期、依赖关系注入等是很多开发框架的常用设计&#xff0c;Dubbo中内置了一个轻量版本的IoC容器&#xff0c;用来管理框架内部的插件&#xff0c;实现包括插件实例化、生命周期、依赖关系自动注入…...

青少年编程与数学 02-016 Python数据结构与算法 26课题、生物信息学算法

青少年编程与数学 02-016 Python数据结构与算法 26课题、生物信息学算法 一、序列比对算法二、基因表达分析算法三、蛋白质结构预测算法四、系统生物学模型构建算法五、单细胞分析算法六、遗传关联分析算法七、机器学习与数据挖掘算法八、数据可视化算法九、代谢组学分析算法十…...

【Rust 精进之路之第2篇-初体验】安装、配置与 Hello Cargo:踏出 Rust 开发第一步

系列&#xff1a; Rust 精进之路&#xff1a;构建可靠、高效软件的底层逻辑 **作者&#xff1a;**码觉客 发布日期&#xff1a; 2025-04-20 引言&#xff1a;磨刀不误砍柴工&#xff0c;装备先行&#xff01; 在上一篇文章中&#xff0c;我们一起探索了 Rust 诞生的缘由&…...

洛谷题目:P7775 [COCI 2009/2010 #2] VUK 题解 (本题简)

题目传送门: P7775 [COCI 2009/2010 #2] VUK - 洛谷 (luogu.com.cn) 前言: 这道题的核心目标是找出狼从起点 V 到终点 J 的路径,使得狼在途中离它最近的树的距离的最小值最大。下面为大家详细讲解: #整体思路概述: 这道题我们可以采用“先计算距离,再来二分查找”的…...

腾讯旗下InstantCharacter框架正式开源 可高度个性化任何角色

目前基于学习的主题定制方法主要依赖于 U-Net 架构&#xff0c;但其泛化能力有限&#xff0c;图像质量也大打折扣。同时&#xff0c;基于优化的方法需要针对特定主题进行微调&#xff0c;这不可避免地会降低文本的可控性。为了应对这些挑战&#xff0c;我们提出了 “即时角色”…...

Python爬虫实战:获取fenbi网最新备考资讯

一、引言 1.1 研究背景 伴随互联网技术的迅猛发展,在线教育平台积累了海量备考数据。以粉某网为例,其备考数据涵盖考试资讯、备考资料、用户评价等,对备考者意义重大。然而,获取并分析这些数据颇具挑战,需借助先进的爬虫技术和数据分析方法。 1.2 研究目的 本研究旨在…...

详讲Linux下进程等待

3.进程等待 引言&#xff1a;什么是进程等待 想象有两个小伙伴&#xff0c;一个是 “大强”&#xff08;父进程 &#xff09;&#xff0c;一个是 “小强”&#xff08;子进程 &#xff09;。大强给小强安排了任务&#xff0c;比如去收集一些石头。 …...

JBoss + WildFly 本地开发环境完全指南

JBoss WildFly 本地开发环境完全指南 本篇笔记主要实现在本地通过 docker 创建 JBoss 和 WildFly 服务器这一功能&#xff0c;基于红帽的禁制 EAP 版本的重新分发&#xff0c;所以我这里没办法放 JBoss EAP 的 zip 文件。WildFly 是免费开源的版本&#xff0c;可以在红帽官网找…...

【网络原理】TCP协议如何实现可靠传输(确认应答和超时重传机制)

目录 一. TCP协议 二. 确定应答 三. 超时重传 一. TCP协议 1&#xff09;端口号 源端口号&#xff1a;发送方端口号目的端口号&#xff1a;接收方端口号 16位&#xff08;2字节&#xff09;端口号&#xff0c;可以表示的范围&#xff08;0~65535&#xff09; 源端口和目的…...

【国家能源集团生态协作平台-注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…...

Java表达式1.0

Java开发工具 在当今的Java开发领域&#xff0c;IntelliJ IDEA已然成为了众多开发者心目中的首选利器&#xff0c;它被广泛认为是目前Java开发效率最快的IDE工具。这款备受瞩目的开发工具是由JetBrains公司精心打造的&#xff0c;而JetBrains公司总部位于风景如画的捷克共和国首…...

idea中导入从GitHub上克隆下来的springboot项目解决找不到主类的问题

第一步&#xff1a;删除目录下的.idea和target&#xff0c;然后用idea打开 第二步&#xff1a;如果有需要&#xff0c;idea更换jdk版本 原文链接&#xff1a;https://blog.csdn.net/m0_74036731/article/details/146779040 解决方法&#xff08;idea中解决&#xff09;&#…...

Android音视频开发

Android Framework 与音视频技术深度解析 一、Android音视频架构全景 ▶ 四层架构协同┌──────────────┐│ 应用层 │ ▶ MediaPlayer/ExoPlayer/Camera2 API调用└──────┬───────┘┌──────▼───────┐│ 框架层 │…...

【AI论文】CLIMB:基于聚类的迭代数据混合自举语言模型预训练

摘要&#xff1a;预训练数据集通常是从网络内容中收集的&#xff0c;缺乏固有的领域划分。 例如&#xff0c;像 Common Crawl 这样广泛使用的数据集并不包含明确的领域标签&#xff0c;而手动整理标记数据集&#xff08;如 The Pile&#xff09;则是一项劳动密集型工作。 因此&…...

Linux操作系统--环境变量

目录 基本概念&#xff1a; 常见环境变量&#xff1a; 查看环境变量的方法&#xff1a; 测试PATH 测试HOME 和环境变量相关的命令 环境变量的组织方式&#xff1a;​编辑 通过代码如何获取环境变量 通过系统调用获取或设置环境变量 环境变量通常具有全局属性 基本概念…...

Jenkins 多分支管道

如果您正在寻找一个基于拉取请求或分支的自动化 Jenkins 持续集成和交付 (CI/CD) 流水线&#xff0c;本指南将帮助您全面了解如何使用 Jenkins 多分支流水线实现它。 Jenkins 的多分支流水线是设计 CI/CD 工作流的最佳方式之一&#xff0c;因为它完全基于 git&#xff08;源代…...

精益数据分析(9/126):如何筛选创业路上的关键数据指标

精益数据分析&#xff08;9/126&#xff09;&#xff1a;如何筛选创业路上的关键数据指标 大家好&#xff01;在创业的漫漫长路中&#xff0c;数据就像一盏明灯&#xff0c;指引着我们前行的方向。但要让这盏灯发挥作用&#xff0c;关键在于找到那些真正有价值的数据指标。今天…...

C语言之图像文件的属性

&#x1f31f; 嗨&#xff0c;我是LucianaiB&#xff01; &#x1f30d; 总有人间一两风&#xff0c;填我十万八千梦。 &#x1f680; 路漫漫其修远兮&#xff0c;吾将上下而求索。 图像文件属性提取系统设计与实现 目录 设计题目设计内容系统分析总体设计详细设计程序实现…...

LeetCode hot 100—分割等和子集

题目 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0c;使得两个子集的元素和相等。 示例 示例 1&#xff1a; 输入&#xff1a;nums [1,5,11,5] 输出&#xff1a;true 解释&#xff1a;数组可以分割成 [1, 5, 5] 和 [11] 。…...

高等数学同步测试卷 同济7版 试卷部分 上 做题记录 上册期中同步测试卷 B卷

上册期中同步测试卷 B卷 一、单项选择题(本大题共5小题,每小题3分,总计15分) 1. 2. 3. 4. 5. 由f(2/n), n→∞可知 2/n→0, 即x→0. 二、填空题(本大题共5小题,每小题3分&#xff0c;总计15分) 6. 7. 8. 9. 10. 三、求解下列各题(本大题共5小…...

【算法】快速排序、归并排序(非递归版)

目录 一、快速排序&#xff08;非递归&#xff09; 1.原理 2.实现 2.1 stack 2.2 partition(array,left,right) 2.3 pivot - 1 > left 二、归并排序&#xff08;非递归&#xff09; 1.原理 2.实现 2.1 gap 2.1.1 i 2*gap 2.1.2 gap * 2 2.1.3 gap < array.…...

python-将文本生成音频

将文本生成音频通常需要结合 文本转语音&#xff08;TTS&#xff0c;Text-to-Speech&#xff09; 工具或库来实现&#xff0c;比如 Google TTS (gtts)、Amazon Polly、Microsoft Azure TTS 等。 一、使用 Google TTS (gtts) 将文本生成音频 gtts 是一个简单易用的 Python 库&a…...