MySQL笔记---Ubuntu环境下从零开始的MySQL

1. 安装MySQL

1.1 自动安装(固定版本)

  • 更新软件包列表:在终端中执行以下命令,以更新系统的软件包列表:

    复制代码
    sudo apt update
  • 安装MySQL服务器:运行以下命令安装MySQL服务器:

    复制代码
    sudo apt install mysql-server

1.2 手动安装(特定版本)

  • 检查是否已安装mysql或mariadb:在终端中执行以下命令,有结果表示已安装:

    复制代码
    sudo dpkg -l | grep mysql-server
    sudo dpkg -l | grep mariadb

2. 首次登录MySQL

2.1 检查mysql是否正常运行

  1. 检查MySQL状态:使用以下命令检查MySQL是否正在运行:

    复制代码
    sudo systemctl status mysql
  2. 启动MySQL服务 :安装完成后,MySQL服务会自动启动。如果未启动,可以使用以下命令启动:

    复制代码
    sudo systemctl start mysql
  3. 可选择将MySQL设置为开机自启动:使用下面的指令来设置开机自启动:

    复制代码
    sudo systemctl enable mysql

2.2 首次登陆

mysql是需要账号密码进行登录后使用的,在mysql安装好之后会默认存在一个root账户,可使用如下的指令进行登录:

bash 复制代码
mysql -u [用户名(root)] -p

此时,会跳出要求你输入密码的提示,可我们并不知道密码。

要完成首次登录,有以下三种方式:

  • 获取临时密码:在终端中执行以下命令,获取临时密码(较新版本可能失效):

    bash 复制代码
    sudo grep 'temporary password' /var/log/mysqld.lo
  • 更改配置文件:在 " etc/my.cnf " 或 " etc/mysql/my.cnf "(可能因版本而不同)中添加:

    bash 复制代码
    [mysqld] # 假如配置文件中本来就包含了这一行,则不用再加
    skip-grant-tables

    添加完成之后,用root账户进行登录时,在输入密码环节可以直接回车跳过。

  • 直接进入:博主自己乱试试出来的:

    bash 复制代码
    sudo mysql

    甚至不会要求你输入密码。

完成登录之后可以使用如下指令设置密码:

bash 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';

也可以使用CREATE USER语句来创建一个新用户。例如,要创建一个名为newuser,密码为password的用户,可以使用以下命令:

bash 复制代码
CREATE USER 'newuser'@'localhost' IDENTIFIED BY 'password';

如果希望用户能从任何主机连接到MySQL服务器,可以将localhost替换为%。但出于安全考虑,建议明确指定来源主机。

至于新用户的权限问题,我们之后再慢慢讨论。

2.3 其他配置

可以在配置文件中添加如下两行配置(似乎在现在的版本中不用配置也可):

bash 复制代码
character-set-server=utf8 #使用utf-8编码格式
default-storage-engine=innodb #使用innodb存储引擎

3. MySQL架构

MySQL当前应用最为广泛的关系型数据库,采用C/S架构,即Client/Server(客户端/服务器)架构。

所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库。

为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据。

数据库服务器、数据库和表的关系如下:

在我们的主机当中查找mysql有关的进程会发现有两个进程:mysql 和 mysqld。

其中,mysql是客户端(Client),而mysqld就是服务端(MySQL),所以在某些操作系统中或MySQL版本中,开始,关闭,重启命令的对象是mysqld。

mysqld的逻辑架构如下:

  • 连接层:负责处理客户端的连接请求,进行身份验证和权限管理。当客户端发送连接请求时,MySQL服务器会在连接层接收请求,分配一个线程来处理该连接,随后进行身份验证。

  • 服务层:是MySQL的核心组件,负责提供各种数据库操作所需的基本功能,如SQL语法处理、事务管理、锁管理等。包括SQL接口、解析器、优化器、缓存等。

  • 引擎层:负责存储数据和执行SQL语句。MySQL支持多种存储引擎,如InnoDB、MyISAM、Memory等,每种引擎各有特点,根据实际需求进行选用。

相关推荐
sunshine-sm16 小时前
CentOS Steam 9安装 MySQL 8
linux·运维·服务器·数据库·mysql·centos·centos stream
DONG99917 小时前
ubuntu 22 安装轻量级桌面Xfce并使用xrdp远程桌面连接
linux·运维·ubuntu
markfeng819 小时前
一文搞懂MySQL字符集
sql·mysql
小白不想白a19 小时前
【MySQL】常用SQL语句
数据库·sql·mysql
RestCloud19 小时前
从MySQL到StarRocks:全量与增量同步的最佳实践
数据库·mysql·api
不会聊天真君64720 小时前
ES(springcloud笔记第五期)
笔记·elasticsearch·spring cloud
汇能感知20 小时前
光谱相机在AI眼镜领域中的应用
经验分享·笔记·科技
汇能感知20 小时前
光谱相机的图像模式
经验分享·笔记·科技
毕设源码纪师姐20 小时前
计算机毕设 java 高校机房综合管控系统 基于 SSM+Vue 的高校机房管理平台 Java+MySQL 的设备与预约全流程系统
java·mysql·课程设计
软测进阶21 小时前
【超详细图文教程】2025年最新Win10 系统安装 MySQL 教程
数据库·mysql