配置和连接另一台电脑上的 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,一经查实,立即删除!

相关文章

VPN,实时数据显示,多线程,pip,venv

VPN和翻墙在本质上是不同的。想要真正实现翻墙,需要选择部署在墙外的VPN服务。VPN也能隐藏用户的真实IP地址 要实现Python对网页数据的定时实时采集和输出,可以使用Python的定时任务调度模块。其中一个常用的库是APScheduler。您可以编写一个函数&#…

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

目录 一、信息系统架构概述 二、信息系统架构风格与分类 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)模式 …

Android 启动时应用的安装解析过程《一》

应用对于Android系统来说至关重要,系统会有几个时机对APP进行解析,一个是APK安装的时候会进行解析,还有一个就是系统在重启之后会进行解析,这里就简单的记录一下重启的时候APK的解析过程。 一、SystemServer 系统在启动之后从内…

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-…

nginx基础使用

文章目录 nginx下载和编译configtest1test2config 原理 nginx 功能: 做为web server 使用在局域网内,提供对外的ip和端口 下载和编译 源码内容: nginx openssl pcrc zlib 编译: 1 cmake 方式: mkdir build cd build cmake 2 ma…

Unity Shader动画:用代码绘制动态视觉效果

在Unity中,Shader是运行在GPU上的小程序,用于控制顶点和像素的渲染过程。通过编写自定义Shader,开发者可以创造出各种令人惊叹的动画效果,从简单的颜色变化到复杂的流体模拟。本文将探讨如何使用Unity Shader来实现动画效果。 Sh…

算法入门篇(五)之 树的应用

目录 1.树和二叉树 1.1树(Tree) 1.1.1 特点 1.1.2 使用场景 1.1.3 示例 1.2二叉树(Binary Tree) 1.2.1 特点 1.2.2 使用场景 1.2.3 示例 2.二叉树遍历 2.1 先序遍历、中序遍历、后序遍历、层次遍历 2.1.1 先序遍历&…

git命令实现github与gitee同步

使用 git remote -v查看远程库连接了啥 git remote set-url --add origin 你的git仓库ssh (意思就是在 远端库origin下面加一个)然后就是git push(这里可能会碰到问题,远程仓库的分支比本地分支更新)注意github(main)与…

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))结果 #按题里的信息,但是结果不对,莱布尼茨函数到底怎么算呀。

本地部署大模型

模型排行榜:https://www.superclueai.com/ Open WebUI https://docs.openwebui.com/ Open WebUI 是一种可扩展、功能丰富且用户友好的自托管 WebUI,旨在完全离线运行。它支持各种 LLM 运行器,包括 Ollama 和 OpenAI 兼容的 API。 docker安装…

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

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

c++实现一个函数,对一个输入的整数,代表时间秒数,将其转换成时间格式字符串,如“01:09:11“,代表1小时,09分,11秒

c实现一个函数&#xff0c;对一个输入的整数&#xff0c;代表时间秒数&#xff0c;将其转换成时间格式字符串&#xff0c;如“01&#xff1a;09&#xff1a;11“&#xff0c;代表1小时&#xff0c;09分&#xff0c;11秒。 #include <iostream> #include <string> …

轻松学EntityFramework Core--模型创建

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