配置和连接另一台电脑上的 MySQL 数据库

要配置和连接另一台电脑上的 MySQL 数据库,可以按照以下步骤进行设置:

1. 配置 MySQL 服务器

在目标计算机上(192.168.10.103)进行以下操作:
  1. 修改 MySQL 配置文件

    • 打开 MySQL 配置文件(通常位于 /etc/mysql/my.cnf/etc/my.cnf)。
    • 找到并注释掉 bind-address 行,或者将其设置为 0.0.0.0 以允许来自任何 IP 地址的连接:
      # bind-address = 127.0.0.1
      bind-address = 0.0.0.0
      
    • 保存并关闭配置文件。
  2. 重新启动 MySQL 服务

    sudo systemctl restart mysql
    

    或者

    sudo service mysql restart
    
  3. 创建远程访问用户并授予权限

    • 登录到 MySQL:
      mysql -u root -p
      
    • 创建用户并授予远程访问权限:
      CREATE USER 'admin'@'192.168.10.103' IDENTIFIED BY '123456';
      GRANT ALL PRIVILEGES ON *.* TO 'admin'@'192.168.10.103' WITH GRANT OPTION;
      FLUSH PRIVILEGES;
      
-- 1. 如果用户已经存在,授予全局权限,允许从任何电脑连接
GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' WITH GRANT OPTION;-- 刷新权限
FLUSH PRIVILEGES;-- 2. 如果用户不存在,先创建用户然后授予权限,允许从任何电脑连接
CREATE USER IF NOT EXISTS 'admin'@'%' IDENTIFIED BY '123456';
GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%' WITH GRANT OPTION;-- 刷新权限
FLUSH PRIVILEGES;-- 3. 创建只针对某个数据库的所有权限
GRANT ALL PRIVILEGES ON yourDBName.* TO 'admin'@'%' WITH GRANT OPTION;-- 刷新权限
FLUSH PRIVILEGES;-- 4. 创建只针对某个数据库的增加、删除、更新权限
GRANT SELECT, INSERT, UPDATE ON yourDBName.* TO 'admin'@'%' WITH GRANT OPTION;-- 刷新权限
FLUSH PRIVILEGES;-- 5. 创建只针对某个数据库的增加、删除、更新权限,并限制远程连接的IP地址
CREATE USER IF NOT EXISTS 'remote_users'@'192.168.1.5' IDENTIFIED BY 'your_secure_password';
GRANT SELECT, INSERT, UPDATE ON yourDBName.* TO 'remote_users'@'192.168.1.5';-- 刷新权限
FLUSH PRIVILEGES;

如果你只需要授予权限给已经存在的用户,请使用第一种语法。如果用户不存在,使用第二种语法来先创建用户然后授予权限。

注意:请确保在使用 GRANT ALL PRIVILEGES 时非常小心,尤其是对 %(所有主机)的权限,因为这会给用户在所有数据库上的所有权限,这在生产环境中可能是不安全的。

2. 配置防火墙

在目标计算机上(192.168.10.103)进行以下操作:
  1. 允许 MySQL 端口(默认是 3306)
    • 使用 ufw(适用于 Ubuntu):
      sudo ufw allow 3306
      
    • 使用 firewalld(适用于 CentOS/RHEL):
      sudo firewall-cmd --permanent --add-port=3306/tcp
      sudo firewall-cmd --reload
      

3. 从本地主机连接到远程 MySQL 服务器

在本地计算机上进行以下操作:
  1. 安装 MySQL 客户端工具(如果未安装):

    • 在 Ubuntu 上:
      sudo apt-get install mysql-client
      
    • 在 CentOS 上:
      sudo yum install mysql
      
  2. 连接到远程 MySQL 服务器

    mysql -u admin -p -h 192.168.10.103
    

    输入密码 123456,你就应该能够连接到远程 MySQL 服务器。

4. 使用图形化工具连接

你也可以使用 MySQL Workbench、DBeaver 或 Navicat 等图形化工具来连接远程 MySQL 服务器。只需在连接设置中输入以下信息:

  • 主机名或 IP 地址:192.168.10.103
  • 端口:3306
  • 用户名:admin
  • 密码:123456

按照上述步骤,你应该能够成功配置和连接到另一台电脑上的 MySQL 数据库。如果在某些步骤中遇到问题,请检查防火墙设置、网络连接和 MySQL 配置是否正确。

5 查看开通的用户

SELECT User, Host FROM mysql.user

在这里插入图片描述

6删除权限,删除用户

要删除MySQL用户的某个特定权限,你可以使用 REVOKE 命令来收回权限。如果你要删除用户的某个连接权限或删除整个用户,分别使用 REVOKE 命令和 DROP USER 命令。

删除特定权限

如果你只想删除用户的特定权限,例如你授予了用户 username 从任何主机(%)连接的权限,现在想删除这个权限:

REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'username'@'%';
删除用户

如果你想完全删除用户 username@%

DROP USER 'username'@'%';
示例操作步骤
  1. 查看当前用户权限
    首先,你可以查看用户的权限,以确保你正在删除正确的权限。

    SHOW GRANTS FOR 'username'@'%';
    
  2. 删除特定权限
    假设你发现用户有对 pdfDB 的权限,你可以具体撤销这些权限:

    REVOKE SELECT, INSERT, UPDATE, DELETE ON pdfDB.* FROM 'username'@'%';
    
  3. 删除用户
    如果你决定完全删除该用户:

    DROP USER 'username'@'%';
    
重新创建用户并设置特定权限

如果你需要重新创建用户并为其设置特定的权限,可以按照之前的方法:

CREATE USER 'username'@'192.168.1.5' IDENTIFIED BY 'password';
GRANT SELECT, INSERT, UPDATE ON pdfDB.* TO 'username'@'192.168.1.5';CREATE USER 'username'@'192.168.1.6' IDENTIFIED BY 'password';
GRANT SELECT, INSERT, UPDATE ON pdfDB.* TO 'username'@'192.168.1.6';

通过这些步骤,你可以撤销用户的全局连接权限或完全删除用户,并根据需要重新创建用户并授予具体权限。

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

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

相关文章

【系统架构设计师】十八、信息系统架构设计理论与实践①

目录 一、信息系统架构概述 二、信息系统架构风格与分类 2.1 信息系统架构风格 2.2 信息系统架构分类 三、信息系统架构模型 3.1 单体应用 3.2 客户机/服务器 3.2.1 二层 C/S 3.2.2 三层 C/S 和 B/S 3.2.3 多层 C/S 和 B/S 3.2.4 MVC 3.3 面向服务架构(SOA)模式 …

Activiti 本地画流程 http://localhost:8080/activiti-app/#/

http://localhost:8080/activiti-app/#/ 1、本地安装了Tomcat 2、本地安装了Activiti 3、拷贝Activiti中这两个文件到Tomcat中的webapps目录下 4、启动startu.bat 5、http://localhost:8080/activiti-app/#/ 账号:admin 密码:test

乐鑫 Matter 技术体验日回顾|全面 Matter 解决方案驱动智能家居新未来

日前,乐鑫信息科技 (688018.SH) 在深圳成功举办了 Matter 方案技术体验日活动,吸引了众多照明电工、窗帘电机、智能门锁、温控等智能家居领域的客户与合作伙伴。活动现场,乐鑫产研团队的小伙伴们与来宾围绕 Matter 产品研发、测试认证、生产工…

Python学习笔记46:游戏篇之外星人入侵(七)

前言 到目前为止,我们已经完成了游戏窗口的创建,飞船的加载,飞船的移动,发射子弹等功能。很高兴的说一声,基础的游戏功能已经完成一半了,再过几天我们就可以尝试驾驶 飞船击毁外星人了。当然,计…

解析西门子PLC的String和WString

西门子PLC有两种字符串类型,String与WString String 用于存放英文数字标点符号等ASCII字符,每个字符占用一个字节 WString宽字符串用于存放中文、英文、数字等Unicode字符,每个字符占用两个字节 之前我搞过一篇解析String的 关于使用TCP-…

Vue3 Pinia的创建与使用代替Vuex 全局数据共享 同步异步

介绍 提供跨组件和页面的共享状态能力,作为Vuex的替代品,专为Vue3设计的状态管理库。 Vuex:在Vuex中,更改状态必须通过Mutation或Action完成,手动触发更新。Pinia:Pinia的状态是响应式的,当状…

Linux内核 mmap内存映射的实现原理

在Linux内核以及Linux系统编程的时候,经常会碰到mmap内存映射,mmap函数是实现高性能编程的一个关键点。本文详细介绍一下mmap实现原理。 虚拟地址映射物理地址 虚拟地址映射物理地址采用的是页表机制,64位CPU采用的是4级页表。 64位CPU虚拟…

鸿蒙 HarmonyOS NEXT端云一体化开发-认证服务篇

一、开通认证服务 地址:AppGallery Connect (huawei.com) 步骤: 1 进入到项目设置页面中,并点击左侧菜单中的认证服务 2 选择需要开通的服务并开通二、端侧项目环境配置 添加依赖 entry目录下的oh-package.json5 // 添加:主要前…

《python程序语言设计》第6章14题 估算派值 类似莱布尼茨函数。但是我看不明白

这个题提供的公式我没看明白,后来在网上找到了莱布尼茨函数 c 0 for i in range(1, 902, 100):a (-1) ** (i 1)b 2 * i - 1c a / bprint(i, round(4 / c, 3))结果 #按题里的信息,但是结果不对,莱布尼茨函数到底怎么算呀。

PyTorch深度学习快速入门(上)

PyTorch深度学习快速入门(上) 一、前言(一)PyTorch环境配置(二)Python编译器的选择(三)Python学习中的两大法宝函数 二、如何加载数据(一)Dataset与Dataloade…

轻松学EntityFramework Core--模型创建

一、使用代码优先(Code-First)创建模型 Code-First 方法是 EF Core 提供的一种用于定义模型的方式,它允许开发人员通过编写 C# 类来定义数据库模式,再通过迁移命令生成数据库表。下面我们来一起看一下代码优先如何使用。 1.1、创…

lua 游戏架构 之 游戏 AI (六)ai_auto_skill

定义一个为ai_auto_skill的类,继承自ai_base类。ai_auto_skill类的目的是在AI自动战斗模式下,根据配置和条件自动选择并使用技能。 lua 游戏架构 之 游戏 AI (一)ai_base-CSDN博客文章浏览阅读379次。定义了一套接口和属性&#…

【原创】使用keepalived虚拟IP(VIP)实现MySQL的高可用故障转移

1. 背景 A、B服务器均部署有MySQL数据库,且互为主主。此处为A、B服务器部署MySQL数据库实现高可用的部署,当其中一台MySQL宕机后,VIP可自动切换至另一台MySQL提供服务,实现故障的自动迁移,实现高可用的目的。具体流程…

快速安装torch-gpu和Tensorflow-gpu(自用,Ubuntu)

要更详细的教程可以参考Tensorflow PyTorch 安装(CPU GPU 版本),这里是有基础之后的快速安装。 一、Pytorch 安装 conda create -n torch_env python3.10.13 conda activate torch_env conda install cudatoolkit11.8 -c nvidia pip ins…

mstc远程连接不锁屏

连接不锁屏 方法一 方法二 win10 解决多用户同时远程连接教程(超详细图文)_win10多用户登录-CSDN博客 win7软件 logout.bat for /f "skip1 tokens3" %%s in (query user %USERNAME%) do (%windir%\System32\tscon.exe %%s /dest:console) …

Datawhale AI 夏令营——AI+逻辑推理——Task1

# Datawhale AI 夏令营 夏令营手册:从零入门 AI 逻辑推理 比赛:第二届世界科学智能大赛逻辑推理赛道:复杂推理能力评估 代码运行平台:魔搭社区 比赛任务 本次比赛提供基于自然语言的逻辑推理问题,涉及多样的场景&…

React Native 与 Flutter:你的应用该如何选择?

Flutter 和 React Native 都被认为是混合应用程序开发中的热门技术。然而,当谈到为你的项目使用框架时,你必须考虑哪一个是最好的:Flutter 还是 React Native? 本篇文章包含 Flutter 和 React Native 在各个方面的差异。因此&…

正则表达式与文本处理

目录 一、正则表达式 1、正则表达式定义 1.1正则表达式的概念及作用 1.2、正则表达式的工具 1.3、正则表达式的组成 2、基础正则表达式 3、扩展正则表达式 4、元字符操作 4.1、查找特定字符 4.2、利用中括号“[]”来查找集合字符 4.3、查找行首“^”与行尾字符“$”…

Lesson 52 What nationality are they? Where do they come from?

Lesson 52 What nationality are they? Where do they come from? 词汇部分 the U.S. 美国 全称:The United States of America    美利坚合众国 其他称呼:the States      the U.S.A.      Uncle Sam Brazil n. 巴西 Brazilian a. 巴…

LeetCode算法——滑动窗口矩阵篇

1、长度最小的子数组 题目描述&#xff1a; 解法&#xff1a; 设一个 for 循环来改变指向窗口末尾的指针&#xff0c;再不断抛弃当前窗口内的首元素 最终确定满足条件的最小长度 class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {int …