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

Linux安全与高级应用(三)深入探索MySQL数据库:安装、管理与安全实践

文章目录

  • 深入探索MySQL数据库:安装、管理与安全实践
    • MySQL数据库简介
    • MySQL的安装与配置
      • 编译安装MySQL
      • 配置MySQL服务
    • MySQL数据库的基本操作
      • 数据库的创建与删除
      • 表的创建与管理
      • 数据记录的增删改查
    • MySQL用户管理与权限设置
    • MySQL数据库的备份与恢复
      • 数据库备份
      • 数据库恢复
    • MySQL安全实践
    • 总结

👍 个人网站:【 洛秋小站】【洛秋资源小站】

深入探索MySQL数据库:安装、管理与安全实践

在现代信息技术的世界里,数据库系统的高效管理和安全维护显得尤为重要。MySQL作为一个开源且广泛使用的关系型数据库管理系统,其性能和安全性得到了众多开发者和企业的认可。本文将从MySQL的安装与配置、数据库的管理与操作、安全机制等方面进行详细探讨,帮助读者全面了解和掌握MySQL数据库系统的使用。

MySQL数据库简介

MySQL是一个开源的关系型数据库管理系统(RDBMS),由瑞典公司MySQL AB开发,目前由Oracle公司维护。其主要特点包括多线程、多用户、基于客户端/服务器(C/S)架构、查询速度快、安全可靠等。MySQL常用于Web开发,是LAMP(Linux、Apache、MySQL、PHP/Perl/Python)开源软件组合中的重要组成部分。

MySQL的安装与配置

编译安装MySQL

MySQL的安装过程可以分为准备工作、源码编译及安装、安装后的调整和添加为系统服务四个步骤。下面是详细步骤:

  1. 准备工作

    确认系统中未安装过MySQL服务器:

    rpm -q mysql-server mysql
    

    安装必要的依赖包,例如ncurses-devel和cmake:

    rpm -ivh /media/RHEL_6.5\ x86_64\ Disc\ 1/Packages/ncurses-devel-5.7-3.20090208.el6.x86_64.rpm
    tar zxf cmake-2.8.6.tar.gz
    cd cmake-2.8.6
    ./configure
    gmake && gmake install
    
  2. 源码编译及安装

    创建mysql用户组和用户,下载并解压MySQL源码包,执行cmake和make命令:

    groupadd mysql
    useradd -M -s /sbin/nologin mysql -g mysql
    tar zxf mysql-5.5.22.tar.gz -C /usr/src/
    cd /usr/src/mysql-5.5.22/
    cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DSYSCONFDIR=/etc -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all
    make
    make install
    
  3. 安装后的其他调整

    更改安装目录权限,配置MySQL系统文件并初始化数据库:

    chown -R mysql:mysql /usr/local/mysql
    cp support-files/my-medium.cnf /etc/my.cnf
    /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/
    echo "PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
    . /etc/profile
    
  4. 添加为系统服务

    将MySQL添加为系统服务,以便通过chkconfig进行管理:

    cp support-files/mysql.server /etc/rc.d/init.d/mysqld
    chmod +x /etc/rc.d/init.d/mysqld
    chkconfig --add mysqld
    

    启动MySQL服务并查看运行状态:

    service mysqld start
    /etc/init.d/mysqld status
    netstat -anpt | grep mysqld
    

配置MySQL服务

MySQL的默认服务端口是3306,可以通过编辑/etc/my.cnf文件中的port参数来更改监听端口。此外,还可以根据需要调整MySQL的其他配置参数,以优化其性能和安全性。

MySQL数据库的基本操作

数据库的创建与删除

创建数据库的命令非常简单,使用CREATE DATABASE命令即可:

CREATE DATABASE auth;

删除数据库则使用DROP DATABASE命令:

DROP DATABASE auth;

表的创建与管理

创建数据表时,需要定义表的字段及其数据类型。例如,创建一个用户表:

CREATE TABLE users (user_name CHAR(16) NOT NULL,user_passwd CHAR(48) DEFAULT '',PRIMARY KEY (user_name)
);

删除表使用DROP TABLE命令:

DROP TABLE users;

数据记录的增删改查

插入数据记录使用INSERT INTO命令:

INSERT INTO users(user_name, user_passwd) VALUES('zhangsan', PASSWORD('123456'));

查询数据记录使用SELECT命令:

SELECT * FROM users WHERE user_name = 'zhangsan';

更新数据记录使用UPDATE命令:

UPDATE users SET user_passwd = PASSWORD('654321') WHERE user_name = 'lisi';

删除数据记录使用DELETE命令:

DELETE FROM users WHERE user_name = 'lisi';

MySQL用户管理与权限设置

MySQL的用户管理和权限设置是确保数据库安全的关键。以下是常用的用户管理命令:

  • 创建用户并授予权限:

    GRANT SELECT ON auth.* TO 'xiaoqi'@'localhost' IDENTIFIED BY '123456';
    
  • 查看用户权限:

    SHOW GRANTS FOR 'xiaoqi'@'localhost';
    
  • 撤销用户权限:

    REVOKE ALL ON auth.* FROM 'xiaoqi'@'localhost';
    

通过以上命令,可以灵活地管理数据库用户及其权限,确保数据的安全性和访问控制。

MySQL数据库的备份与恢复

备份和恢复是保障数据安全的重要措施。MySQL提供了多种备份工具和方法,例如直接备份数据目录或使用mysqldump工具。

数据库备份

使用mysqldump命令备份数据库:

mysqldump -u root -p auth > auth.sql

备份所有数据库:

mysqldump -u root -p --opt --all-databases > all-data.sql

数据库恢复

恢复数据库使用mysql命令:

mysql -u root -p auth < auth.sql

通过以上方法,可以方便地备份和恢复MySQL数据库,确保数据在意外情况下的安全性和可恢复性。

MySQL安全实践

为了提高MySQL数据库的安全性,可以采取以下措施:

  1. 删除默认账户和空账户

    DELETE FROM mysql.user WHERE user = '';
    
  2. 设置强密码
    确保所有数据库用户使用强密码,并定期更新。

  3. 限制访问权限
    只为需要访问的用户授予最低权限,避免权限滥用。

  4. 定期备份
    定期备份数据库,并妥善保管备份文件。

  5. 启用防火墙
    使用防火墙限制数据库服务器的访问范围,只允许可信任的IP地址访问。

通过实施以上安全措施,可以显著提升MySQL数据库的安全性,防止数据泄露和未授权访问。

总结

本文详细介绍了MySQL数据库的安装与配置、基本操作、用户管理与权限设置、备份与恢复以及安全实践。通过系统地学习和掌握这些知识,可以高效地管理和维护MySQL数据库系统,确保数据的安全性和完整性。在实际应用中,还需结合具体的业务需求和环境,灵活运用所学知识,不断优化数据库系统的性能和安全。

👉 最后,愿大家都可以解决工作中和生活中遇到的难题,剑锋所指,所向披靡~

相关文章:

Linux安全与高级应用(三)深入探索MySQL数据库:安装、管理与安全实践

文章目录 深入探索MySQL数据库&#xff1a;安装、管理与安全实践MySQL数据库简介MySQL的安装与配置编译安装MySQL配置MySQL服务 MySQL数据库的基本操作数据库的创建与删除表的创建与管理数据记录的增删改查 MySQL用户管理与权限设置MySQL数据库的备份与恢复数据库备份数据库恢复…...

基于jsp的宠物领养与服务管理系统(源码+论文+部署讲解等)

博主介绍&#xff1a;✌全网粉丝10W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术栈介绍&#xff1a;我是程序员阿龙&#xff…...

基于STM32F407+NBIOT+华为云IOT平台设计的环境检测系统

基于STM32F407NBIOT华为云IOT平台设计的环境检测系统实现的功能&#xff1a; 【1】能够采集本地环境的温度、湿度、烟雾浓度&#xff0c;火光信息&#xff0c;在OLED显示屏上显示。 如果检测到烟雾、温度、火光超过阀值会触发蜂鸣器报警。 【2】能够通过NBIOT将本地设备采集的信…...

工具方法 - 如何表扬小孩子

赞扬小朋友的表现可以通过多种方法来进行&#xff0c;以鼓励他们的积极行为和努力&#xff0c;增强他们的自信心和动力。以下是一些有效的赞扬方法&#xff1a; 1. 具体表扬&#xff1a;指出具体的行为或成就&#xff0c;而不是泛泛地说“你很棒”。例如&#xff0c;“你今天很…...

【扒模块】DySample

逐行注释 import torch import torch.nn as nn import torch.nn.functional as F import warnings# 忽略警告信息&#xff0c;这通常用于开发过程中&#xff0c;避免警告干扰输出结果 warnings.filterwarnings(ignore)# 定义一个函数&#xff0c;用于对神经网络模块的权重进行…...

数学建模之数据分析【四】:变量及其分析

文章目录 一、单变量数据1.1 单变量数据1.2 单变量分析的要点&#xff1a; 二、双变量数据2.1 双变量数据2.2 双变量分析的要点 三、多元数据3.1 多元数据3.2 多元分析的要点 四、单变量&#xff0c;双变量和多变量数据之间的区别 公众号/小红书: 快乐数模 CSDN: 清上尘 本文&a…...

iOS ------ UIKit相关

UIView和CALayer UIView UIView表示屏幕上的一块矩形区域&#xff0c;它是基本上iOS中所有可视化控件的父类。UIView可以管理矩形区域里的内容&#xff0c;处理矩形区域的事件&#xff0c;包括子视图的管理以及动画的实现。 UIKit相关类的继承关系 UIView继承自UIResponde…...

24/8/9算法笔记 随机森林

"极限森林"&#xff08;Extremely Randomized Trees&#xff0c;简称ERT&#xff09;是一种集成学习方法&#xff0c;它属于决策树的变体&#xff0c;通常被归类为随机森林&#xff08;Random Forest&#xff09;的一种。极限森林的核心思想是在构建决策树时引入极端…...

如何在前后端分离项目中,使用Spring Security

使用 WebSecurityConfigurationAdapter 在前后端分离的架构中&#xff0c;通常使用 Token 进行认证和授权是一种常见的做法。Token 可以是 JSON Web Token&#xff08;JWT&#xff09;&#xff0c;用于在客户端和服务器之间传递身份信息和访问控制信息。下面我将详细介绍如何在…...

c#怎么折叠代码快捷

在C#中&#xff0c;‌你可以使用快捷键来折叠或展开代码&#xff0c;‌以便更好地管理和浏览代码。‌以下是一些常用的快捷键&#xff1a;‌ 折叠所有方法&#xff1a;‌使用Ctrl M O。‌折叠或展开当前方法&#xff1a;‌使用Ctrl M M。‌展开所有方法&#xff1a;‌使用…...

数据库篇--八股文学习第十七天| 什么是慢查询?原因是什么?可以怎么优化?;undo log、redo log、binlog 有什么用?

1、什么是慢查询&#xff1f;原因是什么&#xff1f;可以怎么优化&#xff1f; 答&#xff1a; 数据库查询的执行时间超过指定的超时时间时&#xff0c;就被称为慢查询。 原因&#xff1a; 查询语句比较复杂&#xff1a;查询涉及多个表&#xff0c;包含复杂的连接和子查询&…...

插件、cookie存储,json,ajax详解

1.插件 下载地址&#xff1a;http://github.com/carhartl/jquery-cookie/zipball/v1.4.1 使用文档&#xff1a;jquery-cookie(github.com) 2.存储 初学前端用的是localStorage和sessionStorage&#xff0c;后来又引入了cookie进行存储。 localStorage使用如下 sessionStor…...

快速上手Spring Boot

快速上手Spring Boot (qq.com)...

思路超清晰的 LVS-NAT 模式实验部署

目录 一、实验原理 1、实验基础配置图 2、实验原理 二、实验环境准备 1、准备四台红帽9的主机 2、四台主机的基础配置 &#xff08;1&#xff09;client 1&#xff09;配置主机名&#xff1a;client 2&#xff09;配置ip:172.25.254.200 &#xff08;2&#xff09;lv…...

Android实时通信:WebSocket与WebRTC的应用与优化

文章目录 一、WebSocket在Android中的应用1.1 简介1.2 示例 二、WebRTC在Android中的应用2.1 简介2.2 示例 三、Android实时通信的优化策略3.1 网络优化3.2 延迟降低 四、Android实时通信的安全问题五、实时通信协议的比较六、总结 在现代移动应用中&#xff0c;实时通信已经成…...

力扣刷题之3131.找出与数组相加的整数I

题干描述 给你两个长度相等的数组 nums1 和 nums2。 数组 nums1 中的每个元素都与变量 x 所表示的整数相加。如果 x 为负数&#xff0c;则表现为元素值的减少。 在与 x 相加后&#xff0c;nums1 和 nums2 相等 。当两个数组中包含相同的整数&#xff0c;并且这些整数出现的频…...

非线性表之堆的实际应用和二叉树的遍历

目录 前言&#xff1a;前一篇我已经介绍过了二叉树和堆的介绍和相关代码的实现 一、堆的实现 1.1堆向上调整算法 1.2堆向下调整算法 二、堆的应用 2.1堆的排序 2.2TOP-K问题 三、二叉树的遍历 3.1 二叉树的创建 3.2遍历介绍 3.3前序遍历 3.4中序遍历 3.5后序遍历 …...

os.path库学习之splitext函数

os.path库学习之splitext函数 一、简介 os.path.splitext 是 Python 标准库 os.path 模块中的一个函数&#xff0c;用于将文件名分割成两部分&#xff1a;文件名和扩展名。这个函数非常有用&#xff0c;特别是在处理文件路径和文件扩展名时。 二、语法和参数 语法: os.path…...

Python知识点:如何使用Sqlmap进行SQL注入测试

使用 Sqlmap 进行 SQL 注入测试是一个非常有效的方法&#xff0c;它可以帮助你自动化地检测和利用 SQL 注入漏洞。以下是使用 Sqlmap 进行 SQL 注入测试的详细步骤&#xff1a; 1. 安装 Sqlmap 首先&#xff0c;你需要安装 Sqlmap。Sqlmap 是一个 Python 工具&#xff0c;因此…...

Android Gradle开发与应用 (一) : Gradle基础

Gradle基础 Gradle 是一个基于 Apache Ant 和 Apache Maven 概念的项目自动化构建工具。它使用一种基于 Groovy 的特定领域语言&#xff08;DSL&#xff09;来声明项目设置&#xff0c;而不是传统的 XML。Gradle 提供了灵活的构建脚本和强大的依赖管理功能&#xff0c;使其成为…...

设计模式和设计原则回顾

设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

FFmpeg 低延迟同屏方案

引言 在实时互动需求激增的当下&#xff0c;无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作&#xff0c;还是游戏直播的画面实时传输&#xff0c;低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架&#xff0c;凭借其灵活的编解码、数据…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建

制造业采购供应链管理是企业运营的核心环节&#xff0c;供应链协同管理在供应链上下游企业之间建立紧密的合作关系&#xff0c;通过信息共享、资源整合、业务协同等方式&#xff0c;实现供应链的全面管理和优化&#xff0c;提高供应链的效率和透明度&#xff0c;降低供应链的成…...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例

文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?

Otsu 是一种自动阈值化方法&#xff0c;用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理&#xff0c;能够自动确定一个阈值&#xff0c;将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...

SpringCloudGateway 自定义局部过滤器

场景&#xff1a; 将所有请求转化为同一路径请求&#xff08;方便穿网配置&#xff09;在请求头内标识原来路径&#xff0c;然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...

SpringTask-03.入门案例

一.入门案例 启动类&#xff1a; package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...

PostgreSQL——环境搭建

一、Linux # 安装 PostgreSQL 15 仓库 sudo dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-$(rpm -E %{rhel})-x86_64/pgdg-redhat-repo-latest.noarch.rpm# 安装之前先确认是否已经存在PostgreSQL rpm -qa | grep postgres# 如果存在&#xff0…...

毫米波雷达基础理论(3D+4D)

3D、4D毫米波雷达基础知识及厂商选型 PreView : https://mp.weixin.qq.com/s/bQkju4r6med7I3TBGJI_bQ 1. FMCW毫米波雷达基础知识 主要参考博文&#xff1a; 一文入门汽车毫米波雷达基本原理 &#xff1a;https://mp.weixin.qq.com/s/_EN7A5lKcz2Eh8dLnjE19w 毫米波雷达基础…...