Enable remote access for mysql under Ubuntu

Keywords: MySQL Database SSL Oracle

1. Log in with root

  1. admin@lnxServer:~$ mysql -uroot -p123456  
  2. Warning: Using a password on the command line interface can be insecure.  
  3. Welcome to the MySQL monitor.  Commands end with ; or \g.  
  4. Your MySQL connection id is 154  
  5. Server version: 5.6.19-0ubuntu0.14.04.1 (Ubuntu)  
  6.   
  7. Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.  
  8.   
  9. Oracle is a registered trademark of Oracle Corporation and/or its  
  10. affiliates. Other names may be trademarks of their respective  
  11. owners.  
  12.   
  13. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.  

2. Execute the use mysql command

  1. mysql> use mysql;  
  2. Reading table information for completion of table and column names  
  3. You can turn off this feature to get a quicker startup with -A  
  4.   
  5. Database changed  

3. Add users and assign permissions

  1. mysql> grant all privileges on *.* to zcloud@'%' identified by 'Passw0rd' with grant option;  
  2. Query OK, 0 rows affected (0.05 sec)  
Statement resolution:

*. * = = > database.table, that is, database name and table name

Zcloud = = = > specifies the user name. If the user name exists in the database, it will be updated. If not, it will be a new user

The string after @ indicates the host that allows remote login. For example, localhost indicates the local host and% indicates any host. If you need to specify the login host, you can use the IP address.

'Passw0rd' user password, specify the user's login password, and customize any character.             

4. Save, flush privileges

  1. mysql> flush privileges;  
  2. Query OK, 0 rows affected (0.02 sec)  
  3.   
  4. <pre name="code" class="plain">mysql>quit  
Bye


5. Restart mysql service
  1. admin@lnxServer:~$ sudo service mysql restart  
  2. [sudo] password for admin:   
  3. mysql stop/waiting  
  4. mysql start/running, process 22074  

6. Modify the mysql configuration file. The files corresponding to different versions may be my.cnf or mysql d.conf.d

Find the line with bind address = 127.0.0.1, and add "comment" before it

The profile reference is as follows

mysqld.conf.d

  1. #  
  2. # The MySQL database server configuration file.  
  3. #  
  4. # You can copy this to one of:  
  5. # - "/etc/mysql/my.cnf" to set global options,  
  6. # - "~/.my.cnf" to set user-specific options.  
  7. #  
  8. # One can use all long options that the program supports.  
  9. # Run program with --help to get a list of available options and with  
  10. # --print-defaults to see which it would actually understand and use.  
  11. #  
  12. # For explanations see  
  13. # http://dev.mysql.com/doc/mysql/en/server-system-variables.html  
  14.   
  15. # This will be passed to all mysql clients  
  16. # It has been reported that passwords should be enclosed with ticks/quotes  
  17. # escpecially if they contain "#" chars...  
  18. # Remember to edit /etc/mysql/debian.cnf when changing the socket location.  
  19.   
  20. # Here is entries for some specific programs  
  21. # The following values assume you have at least 32M ram  
  22.   
  23. [mysqld_safe]  
  24. socket          = /var/run/mysqld/mysqld.sock  
  25. nice            = 0  
  26.   
  27. [mysqld]  
  28. #  
  29. # * Basic Settings  
  30. #  
  31. user            = mysql  
  32. pid-file        = /var/run/mysqld/mysqld.pid  
  33. socket          = /var/run/mysqld/mysqld.sock  
  34. port            = 3306  
  35. basedir         = /usr  
  36. datadir         = /var/lib/mysql  
  37. tmpdir          = /tmp  
  38. lc-messages-dir = /usr/share/mysql  
  39. skip-external-locking  
  40. #  
  41. # Instead of skip-networking the default is now to listen only on  
  42. # localhost which is more compatible and is not less secure.  
  43. #bind-address           = 127.0.0.1  
  44. #  
  45. # * Fine Tuning  
  46. #  
  47. key_buffer_size         = 16M  
  48. max_allowed_packet      = 16M  
  49. thread_stack            = 192K  
  50. thread_cache_size       = 8  
  51. # This replaces the startup script and checks MyISAM tables if needed  
  52. # the first time they are touched  
  53.  myisam-recover         = BACKUP  
  54. #max_connections        = 100  
  55. #table_cache            = 64  
  56. #thread_concurrency     = 10  
  57. #  
  58. # * Query Cache Configuration  
  59. #  
  60. query_cache_limit       = 1M  
  61. query_cache_size        = 16M  
  62. #  
  63. # * Logging and Replication  
  64. #  
  65. # Both location gets rotated by the cronjob.  
  66. # Be aware that this log type is a performance killer.  
  67. # As of 5.1 you can enable the log at runtime!  
  68. #general_log_file        = /var/log/mysql/mysql.log  
  69. #general_log             = 1  
  70. #   
  71. # Error log - should be very few entries.  
  72. #  
  73. log_error = /var/log/mysql/error.log  
  74. #  
  75. # Here you can see queries with especially long duration  
  76. #log_slow_queries       = /var/log/mysql/mysql-slow.log  
  77. #long_query_time = 2  
  78. #log-queries-not-using-indexes  
  79. #  
  80. # The following can be used as easy to replay backup logs or for replication.  
  81. # note: if you are setting up a replication slave, see README.Debian about  
  82. #       other settings you may need to change.  
  83. #server-id              = 1  
  84. #log_bin                        = /var/log/mysql/mysql-bin.log  
  85. expire_logs_days        = 10  
  86. max_binlog_size   = 100M  
  87. #binlog_do_db           = include_database_name  
  88. #binlog_ignore_db       = include_database_name  
  89. #  
  90. # * InnoDB  
  91. #  
  92. # InnoDB is enabled by default with a 10MB datafile in /var/lib/mysql/.  
  93. # Read the manual for more InnoDB related options. There are many!  
  94. #  
  95. # * Security Features  
  96. #  
  97. # Read the manual, too, if you want chroot!  
  98. # chroot = /var/lib/mysql/  
  99. #  
  100. # For generating SSL certificates I recommend the OpenSSL GUI "tinyca".  
  101. #  
  102. # ssl-ca=/etc/mysql/cacert.pem  
  103. # ssl-cert=/etc/mysql/server-cert.pem  
  104. # ssl-key=/etc/mysql/server-key.pem  

6.OK, you can use the client to access it.

Posted by Shygirl on Fri, 01 May 2020 01:25:14 -0700