ホームページ データベース mysql チュートリアル Linux允许MySQL数据库远程访问方法

Linux允许MySQL数据库远程访问方法

Jun 07, 2016 pm 05:52 PM

远程连接MySQL出于安全考虑,一般都关闭了远程访问,但有时候需要提供远程访问数据库的服务,下面我们介绍两种开启mysql远程连接的方法。

Mysql默认root用户只能本地访问,不能远程连接管理mysql数据库,Linux如何开启mysql远程连接?设置步骤如下:
1、GRANT命令创建远程连接mysql授权用户itlogger

 代码如下 复制代码

mysql -u root -p
mysql>GRANT ALL PRIVILEGES ON *.* TO itlogger@localhost IDENTIFIED BY ‘www.itlogger.com’ WITH GRANT OPTION;
mysql>GRANT ALL PRIVILEGES ON *.* TO itlogger@”%” IDENTIFIED BY ‘www.itlogger.com’ WITH GRANT OPTION;

第一句增加itlogger用户授权通过本地机(localhost)访问,密码“www.itlogger.com”。第二句则是授与itlogger用户从任何其它主机发起的访问(通配符%)。
2、设置防火墙允许3306端口
vi /etc/sysconfig/IPtables
添加-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT
(注意添加在-A RH-Firewall-1-INPUT -j REJECT –reject-with icmp-host-prohibited之前,否则可能导致规则不生效)
重启防火墙service iptables restart
3、附:Mysql无法远程连接的常见问题

1)查看Mysql的端口是否正确,通过netstat -ntlp查看端口占用情况,一般情况下端口是3306。

2)报错:ERROR 2003 (HY000): Can’t connect to MySQL server on ’192.168.51.112′ (111)
查看/etc/my.cnf中,skip-networking 是否已被注掉,需要注掉。
3)报错:ERROR 2003 (HY000): Can’t connect to MySQL server on ’192.168.51.112′ (113)
查看是否iptables没有允许mysql连接,通过:service iptables stop临时关闭测试是否可以正常远程访问,如果可以,按上面方面设置iptable允许3306端口
4)远程访问mysql速度很慢的解决方法
修改/etc/my.cnf或my.ini
[mysqld]下添加

 代码如下 复制代码
skip-name-resolve
skip-grant-tables

方法二 修改my.ini

第一步:修改my.cnf文件

使用文本编辑器去编辑MySQL服务器的配置文件my.cnf

 如果你使用Debian Linux,文件位置在: /etc/mysql/my.cnf

如果你使用Red Hat Linux/Fedora/Centos Linux,文件位置在: /etc/my.cnf

如果你使用FreeBSD,文件位置在: /var/db/mysql/my.cnf

 如果使用VI编辑,直接使用命令

 代码如下 复制代码

 # vi /etc/my.cnf

 

第二步:如果文件打开,按照下面内容进行

[mysqld]

 确保skip-networking是被注释的,或者被删除,然后添加下面一行内容

 bind-address=你的服务器IP

 例如,你的服务器IP是65.55.55.2,然后需要配置例如如下的内容:

 代码如下 复制代码

 [mysqld]

user            = mysql

pid-file        = /var/run/mysqld/mysqld.pid

socket          = /var/run/mysqld/mysqld.sock

port            = 3306

basedir         = /usr

datadir         = /var/lib/mysql

tmpdir          = /tmp

language        = /usr/share/mysql/English

bind-address    = 65.55.55.2

# skip-networking

....

..

....

 

 

这里面

bind-address : 你需要绑定的IP地址.

skip-networking : 开启 skip-networking 选项可以彻底关闭MySQL的TCP/IP连接方式,在一些文档中也提到在单机运行的 MySQL 推荐开启该选项,现在看,不太靠谱。

 

第三步:保存并且关闭文件

重启你的MySQL服务器,在命令行输出

# /etc/init.d/mysql restart

 第四步:绑定远程IP地址的管理权限

连接MySQL服务器:

 $ mysql -u root -p mysql

 绑定权限到新的数据表(这一步可以借助phpmyadmin这类的工具简单完成,这里只是个例子)

 如果我们需要绑定一个远程ip 202.54.10.20到新建的foo数据库下的bar用户中,在命令行中输入:

 

 代码如下 复制代码

mysql> CREATE DATABASE foo;

mysql> GRANT ALL ON foo.* TO bar@'202.54.10.20' IDENTIFIED BY 'PASSWORD';

 

如何绑定一个已经存在的数据库呢?

 代码如下 复制代码

mysql> update db set Host='202.54.10.20' where Db='webdb';

mysql> update user set Host='202.54.10.20' where user='webadmin';

 

第四步:推出MySQL

输入下面的命令:

 代码如下 复制代码

mysql> quit;

 第五步:打开3306

端口

需要将TCP端口3306开启,使用iptables或者BSD的pf 防火墙

 Linux下iptables的例子

/sbin/iptables -A INPUT -i eth0 -p tcp --destination-port 3306 -j ACCEPT

 或者如果你只需要允许特定的服务器,ip为10.5.1.3,可以这样:

 /sbin/iptables -A INPUT -i eth0 -s 10.5.1.3 -p tcp --destination-port 3306 -j ACCEPT

 或者仅仅允许自己子网内的远程连接范围192.168.1.0/24

 /sbin/iptables -A INPUT -i eth0 -s 192.168.1.0/24 -p tcp --destination-port 3306 -j ACCEPT

 最后保存所有规则

 # service iptables save

 FreeBSD / OpenBSD pf 的规则( /etc/pf.conf)

 pass in on $ext_if proto tcp from any to any port 3306

 或者允许允许ip:10.5.1.3

pass in on $ext_if proto tcp from 10.5.1.3 to any port 3306  flags S/SA synproxy state

 第六步:测试

 你远程主机上面打开cmd,输入:

mysql -u webadmin –h 65.55.55.2 –p

 在这里

-u webadmin: webadmin 是MySQL服务器的用户

-h IP or 服务器名称: 65.55.55.2 is MySQL 服务器IP地址

-p : 密码

 你同样可以使用telnet来连接到3306端口

 $ telnet 65.55.55.2 3306

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

デバイス マネージャーにリモートで接続し、接続の問題をトラブルシューティングするにはどうすればよいですか? デバイス マネージャーにリモートで接続し、接続の問題をトラブルシューティングするにはどうすればよいですか? Apr 27, 2023 pm 03:10 PM

デバイス マネージャーは、Microsoft が提供する管理コンソールの拡張機能として定義できます。これにより、コンピュータに接続されているハードウェア デバイスを一元的に整理したビューがユーザーに提供されます。デバイス マネージャーにアクセスするのは簡単ですが、リモートのデバイス マネージャーに接続するにはどうすればよいでしょうか?リモートデバイスとは何ですか?デバイス マネージャーにリモートで接続する前に、リモート デバイスとは何かご存知ですか?リモート デバイスは、物理的にアクセスできないが、ネットワーク リンクまたはリモート コントロール ソフトウェアを使用してリモート アクセスできる任意のデバイスとして定義できます。リモートアクセスの例にはどのようなものがありますか?多くのデバイスにリモートからアクセスできます。あなたがオープンプランのオフィスで働いていると仮定しましょう。オフィスには全従業員が共有するプリンターがあります。デスクからプリンターにリモートでアクセスできます。他のリモート アクセスの例には、リモート アクセス コンピューティングが含まれます。

PHP 開発の実践: PHPMailer を使用して MySQL データベース内のユーザーに電子メールを送信する PHP 開発の実践: PHPMailer を使用して MySQL データベース内のユーザーに電子メールを送信する Aug 05, 2023 pm 06:21 PM

PHP 開発の実践: PHPMailer を使用して MySQL データベース内のユーザーに電子メールを送信する はじめに: 現代のインターネットの構築において、電子メールは重要なコミュニケーション ツールです。 ECにおけるユーザー登録やパスワードのリセット、注文確認など、メール送信は欠かせない機能です。この記事では、PHPMailer を使用してメールを送信し、メール情報を MySQL データベースのユーザー情報テーブルに保存する方法を紹介します。 1. PHPMailer ライブラリをインストールする PHPMailer は

PHP を介して Modbus TCP リモート アクセスを実装する方法 PHP を介して Modbus TCP リモート アクセスを実装する方法 Jul 17, 2023 pm 07:49 PM

PHP を介して Modbus TCP リモート アクセスを実装する方法 Modbus は、産業オートメーションの分野でコントローラーとデバイスの間でデータを交換するために使用される通信プロトコルです。 ModbusTCP は、イーサネット上の TCP/IP 通信に基づく Modbus プロトコルです。 PHP言語を使用すると、ModbusTCPへのリモートアクセスを簡単に実装できます。この記事では、PHP を介して ModbusTCP リモート アクセスを実装する方法とサンプル コードを紹介します。ステップ 1: インストール

Windows 11でリモートデスクトップを無効にする方法 Windows 11でリモートデスクトップを無効にする方法 Apr 14, 2023 pm 03:16 PM

Windows 11 でリモート デスクトップを無効にする方法 リモート デスクトップを使用すると、正しいユーザー名とパスワードを持つ人なら誰でも PC にアクセスできます。これは一般的な攻撃戦術ではありませんが、発生する可能性があります。ユーザーが PC にアクセスすると、悪意のある者がファイル、アプリケーション、その他のアカウントの資格情報にアクセスできるようになります。 RDP は一般にセキュリティ機能ですが、使用しない場合は無効にすることで、潜在的に悪意のあるリモートの脅威からの攻撃を排除できます。したがって、RDP を無効にする方法はいくつかありますので、その方法を説明します。欲しい

Go 言語と MySQL データベース: ホット データとコールド データを分離するには? Go 言語と MySQL データベース: ホット データとコールド データを分離するには? Jun 18, 2023 am 08:26 AM

データ量が増加し続けるにつれて、データベースのパフォーマンスがますます重要な問題になっています。ホット データとコールド データの分離処理は、ホット データとコールド データを分離できる効果的なソリューションであり、それによってシステムのパフォーマンスと効率が向上します。この記事では、Go 言語と MySQL データベースを使用してホット データとコールド データを分離する方法を紹介します。 1. ホットデータとコールドデータの分離処理とは ホットデータとコールドデータの分離処理とは、ホットデータとコールドデータを分類する方法です。ホット データとは、アクセス頻度が高く、パフォーマンス要件が高いデータを指します。

MySQL データベースを時系列分析に使用するにはどうすればよいですか? MySQL データベースを時系列分析に使用するにはどうすればよいですか? Jul 12, 2023 am 08:39 AM

MySQL データベースを時系列分析に使用するにはどうすればよいですか?時系列データとは、時間的な連続性と相関性を持つ、時系列に並べられたデータの集合のことです。時系列分析は、将来の傾向の予測、周期的な変化の発見、外れ値の検出などに使用できる重要なデータ分析手法です。この記事では、MySQL データベースを使用して時系列分析を行う方法とコード例を紹介します。データ テーブルを作成する まず、時系列データを保存するデータ テーブルを作成する必要があります。数値を分析したいとします。

Go 言語を使用して MySQL データベースの増分データ バックアップを実行する方法 Go 言語を使用して MySQL データベースの増分データ バックアップを実行する方法 Jun 17, 2023 pm 02:28 PM

データ量が増加するにつれて、データベースのバックアップの重要性がますます高まります。 MySQL データベースの場合、Go 言語を使用して自動増分バックアップを実現できます。この記事では、Go 言語を使用して MySQL データベース データの増分バックアップを実行する方法を簡単に紹介します。 1. Go 言語環境をインストールする まず、Go 言語環境をローカルにインストールする必要があります。公式 Web サイトにアクセスして、対応するインストール パッケージをダウンロードしてインストールできます。 2. 対応するライブラリをインストールする Go 言語には、MySQL データベースにアクセスするための多くのサードパーティ ライブラリが用意されています。

MySQL データベースのスキルをどの程度まで開発すれば、うまく活用できるでしょうか? MySQL データベースのスキルをどの程度まで開発すれば、うまく活用できるでしょうか? Sep 12, 2023 pm 06:42 PM

MySQL データベースのスキルをどの程度まで開発すれば、うまく活用できるでしょうか?情報化時代の急速な発展に伴い、データベース管理システムはあらゆる分野で不可欠かつ重要なコンポーネントになりました。一般的に使用されるリレーショナル データベース管理システムとして、MySQL には幅広い応用分野と雇用機会があります。では、MySQL データベースのスキルを適切に活用するには、どの程度まで開発する必要があるのでしょうか?まず、MySQL の基本原理と基礎知識を習得することが最も基本的な要件です。 MySQL はオープンソースのリレーショナル データベース管理です

See all articles