Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

WBOY
WBOYke hadapan
2023-05-31 08:09:151567semak imbas

Latar Belakang

Pelayan awan yang digunakan ialah Baidu Cloud (perkara yang sama berlaku untuk pelayan awan lain Sistem ini ialah Ubuntu 20.04 LTS, Mysql versi 8.0+, dan anda boleh menyambung dari jauh untuk membaca dan menulis pada bila-bila masa Mysql pada pelayan

Mewujudkan sambungan jauh ke pelayan

Anda boleh menggunakan klien ssh atau konsol web yang disediakan oleh pengeluar pelayan awan, selagi anda boleh menyambung ke pelayan

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

Oleh itu, saya ingin secara peribadi mengesyorkan pelanggan ssh yang tampan dan mudah digunakan: NextSSH

Gunakan apt-get untuk memasang mysql

Kemas kini repositori apt dahulu:

sudo apt-get update

By the way, kerana saya tidak tahu akaun apa yang anda gunakan, dan saya boleh' t mengetahui arahan yang memerlukan kebenaran yang lebih tinggi, jadi saya menambahkan sudo pada semua arahan supaya tidak kira siapa yang menyalin dan menampalnya Ia boleh digunakan terus tanpa sebarang masalah kebenaran.
Kemudian pasang mysql-server:

sudo apt-get install mysql-server -y

Pada langkah ini, mysql telah dipasang dan dimulakan secara automatik Anda boleh melihat:

sudo service mysql status

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

. Tetapkan kata laluan akar

Pada masa ini, akaun akar mysql tidak mempunyai kata laluan yang ditetapkan Anda boleh log masuk terus dengan perintah mysql:

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

<.>Tetapkan kata laluan akar ( kepada kata laluan yang anda ingin tetapkan):

ALTER USER &#39;root&#39;@&#39;localhost&#39; IDENTIFIED WITH mysql_native_password by &#39;mynewpassword&#39;;
mynewpassword

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhKeluar, masukkan perintah

dan dapatkan bahawa anda tidak boleh log masuk terus:

mysql

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhKini anda boleh menggunakan mysql terus pada pelayan.

Edit fail konfigurasi untuk memantau sambungan jauh

Secara lalai, pangkalan data MySQL hanya memantau sambungan setempat Jika anda ingin membenarkan rangkaian luaran menyambung ke pangkalan data dari jauh, kami perlu mengubah suai fail konfigurasi supaya MySQL boleh memantau sambungan jauh IP atau mendengar pada semua IP jauh.

Anda perlu menggunakan editor teks baris arahan di sini saya menggunakan vim, jadi saya akan mengajar anda vim Jika anda tahu nano atau perkara lain, anda akan tahu bagaimana untuk melakukannya, ikuti sahaja arahan saya. Pasang vim:

sudo apt-get install vim -y

Kemudian buka fail konfigurasi

dengan vim:

sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
mysqld.cnfCari baris

:

bind-address = 127.0.0.1

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh ini Apabila nilai ialah

, ia hanya memantau sambungan tempatan Jika ia ditukar kepada

, ia boleh memantau semua sambungan, atau ia juga boleh ditukar untuk membenarkan sambungan daripada IP yang ditentukan. 127.0.0.1Kini vim berada dalam mod membaca Klik 0.0.0.0 untuk memasuki mod pengeditan, dan kemudian gunakan kekunci atas, bawah, kiri dan kanan untuk mencari baris ini (apabila INSERT dipaparkan di bahagian bawah, ia menunjukkan bahawa ia berada dalam. mod penyuntingan. Tekan Esc untuk keluar dan kembali ke mod membaca):
i

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhSelepas membuat perubahan, tekan Esc untuk keluar dari mod penyuntingan, kemudian masukkan

untuk menyimpan dan keluar . (Jika anda memasukkan

, anda akan keluar tanpa menyimpan) :wqMulakan semula perkhidmatan mysql untuk membuat perubahan berkuat kuasa: :q

sudo service mysql restart

Benarkan akaun root menggunakan sambungan jauh

Oleh lalai, mysql hanya membenarkan akaun root disambungkan Untuk kegunaan tempatan, anda perlu mengubah suainya untuk membenarkan penggunaan jauh akaun root (saya belum mencubanya dengan akaun lain, tetapi prinsipnya adalah sama). Log masuk pertama ke mysql:

mysql -u root -p
Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhMasukkan kata laluan dan log masuk.

Kemudian pilih

Pangkalan Data:

use mysql;
mysql

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhLihat kebenaran hos akaun:

select user, host from user;

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

hanya dibenarkan untuk kegunaan tempatan apabila ia

Tukar kepada host untuk kegunaan jauh: localhost

update user set host=&#39;%&#39; where user=&#39;root&#39;;
%

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhKeluar dari mysql.

Semak status firewall yang disertakan dengan ubuntu

sudo ufw status

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauhJika ia

bermakna firewall tidak dihidupkan, maka jangan' jangan risau. Apakah tujuan firewall? Pemahaman saya sendiri ialah jika firewall dihidupkan, semua port pada pelayan dilarang bersambung secara lalai Hanya port yang anda benarkan dibenarkan untuk menyambung, seperti ini:

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

所以如果防火墙开了,那要么把防火墙直接关了:

sudo ufw disable

要么添加一条规则让防火墙放行3306端口(mysql的默认端口):

sudo ufw allow 3306

检查云服务器厂商的防火墙状态

打开云服务器的后台管理页面,找到防火墙:

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

云服务器厂商默认只开启几个最常用的端口,其他端口都是默认关闭的,所以也要在这里添加一条规则放行3306端口:

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

测试连接

随便找个数据库管理的软件测试一下:

Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh

Atas ialah kandungan terperinci Bagaimana untuk memasang Mysql di Ubuntu untuk membolehkan sambungan jauh. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam