GVKun编程网logo

MySQL--局域网、外网访问MySQL(mysql 外网访问)

4

本篇文章给大家谈谈MySQL--局域网、外网访问MySQL,以及mysql外网访问的知识点,同时本文还将给你拓展Apache设置本地(局域网)访问、C#实现获取本地内网(局域网)和外网(公网)IP地址

本篇文章给大家谈谈MySQL--局域网、外网访问MySQL,以及mysql 外网访问的知识点,同时本文还将给你拓展Apache 设置本地(局域网)访问、C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析、centos7 设置 mysql 自启动的配置文件中 [Service] User=mysql Group=mysql,user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?、docker 容器下 mysql 更改 WordPress 的 site address 和 home(URL)------ 局域网等相关知识,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

MySQL--局域网、外网访问MySQL(mysql 外网访问)

MySQL--局域网、外网访问MySQL(mysql 外网访问)

一、局域网、外网访问

 1. 打开CMD,导航到当前MySQL的bin路径,如下图:

2. 访问MySQL:输入MySQL -u root -p,点击Enter键,即可看到密码输入框:

输入密码,点需Enter键确定,即可看到如下图:表示访问MySQL成功。

3. 选择数据库:输入use mysql;

4. 添加局域网访问:输入update user set host = ''%'' where user = ''root'';

点击确定,出现如下图,表示更新权限成功;

或者使用语句:

 GRANT ALL PRIVILEGES ON *.* TO '' root ''@''localhost''  IDENTIFIED BY ''123456'';

5. 刷新权限:输入flush privileges; 点击Enter键确定,出现如下图,表示刷新成功;

6. 使用Navicat连接Mysql(局域网连接);

  

测试连接,点击连接测试:

 

 

如果操作命令不熟悉,也可以用第二种方法:

二、登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%" 或添加一个用户为“%”  。    

想让局域网中的所有机器都能连接MySQL数据库,首先要给MySQL开启远程连接的功能,在MySQL服务器控制台上执行MySQL命令:

grant all privileges on *.* to root@"%" identified by ''abc'' with grant option;  
flush privileges;

 

其中上面两行代码的意思是给从任意ip地址连接的用户名为root,密码为abc的用户赋予所有的权限。其中的"%"为任意的ip地址,如果想设为特定的值也可以设定为特定的值(以通配符%的内容增加主机/IP地址,也可以直接增加IP地址)。

做完这些之后,局域网内的mysql服务器可以访问了。

 

Apache 设置本地(局域网)访问

Apache 设置本地(局域网)访问

打开apache安装路径中的http.conf文件 找打以下内容

#onlineoffline tag - don''t remove   
Order Deny,Allow   
Deny from all   
Allow from 127.0.0.1  

在Deny from all 前加上#来注释掉此行,并在Allow from 127.0.0.1 后面加上一行Allow from 192.168.1.* 或者 Allow from all 即可。修改后如下:

#onlineoffline tag - don''t remove   
Order Deny,Allow   
#   Deny from all   
Allow from 127.0.0.1  
Allow from 192.168.1.*

C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析

C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析

本文实例讲述了C#实现获取本地内网(局域网)和外网(公网)IP地址的方法。分享给大家供大家参考,具体如下:

1、获取本机的IP地址集合:

/// <summary>
  /// 获取本机所有ip地址
  /// </summary>
  /// <param name="netType">"InterNetwork":ipv4地址,"InterNetworkV6":ipv6地址</param>
  /// <returns>ip地址集合</returns>
  public static List<string> GetLocalIpAddress(string netType)
  {
   string hostName = Dns.GetHostName();     //获取主机名称 
   IPAddress[] addresses = Dns.GetHostAddresses(hostName); //解析主机IP地址 

   List<string> IPList = new List<string>();
   if (netType==string.Empty)
   {
    for (int i = 0; i < addresses.Length; i++)
    {
     IPList.Add(addresses[i].ToString());
    }
   }
   else
   {
    //AddressFamily.InterNetwork表示此IP为IPv4,
    //AddressFamily.InterNetworkV6表示此地址为IPv6类型
    for (int i = 0; i < addresses.Length; i++)
    {
     if (addresses[i].AddressFamily.ToString() == netType)
     {
      IPList.Add(addresses[i].ToString());
     }
    }
   }
   return IPList;
  }

  List<string> ips= GetLocalIpAddress("");//获取本地所有ip
  List<string> ipv4_ips = GetLocalIpAddress("InterNetwork");//获取ipv4类型的ip
  List<string> ipv6_ips = GetLocalIpAddress("InterNetworkV6");//获取ipv6类型的ip

2、获取本机局域网内IP地址:

如果本机在局域网内,直接调用上面的方法即可,以ipv4为例:

List<string> ipv4_ips = GetLocalIpAddress("InterNetwork");

如果本机只有一个网卡,且没有安装虚拟网卡,那么ipv4_ips里应该只有一条数据,即局域网内地址;

3、获取本机的公网IP地址:

1)、如果本机是拨号上网的或具有独立公网IP的情况下,使用上面的方法即可,以ipv4为例:

List<string> ipv4_ips = GetLocalIpAddress("InterNetwork");

如果本机只有一个网卡,且没有安装虚拟网卡,那么ipv4_ips里应该只有一条数据,即公网IP地址;

2)、如果是路由上网的,想获取网关的外网IP,只能通过访问一些公网的地址来获取外网IP了;

步骤:先获取到含有本机外网ip的页面信息,再通过正则获取到ip信息;

/// <summary>
  /// 获取页面html
  /// </summary>
  /// <param name="url">请求的地址</param>
  /// <param name="encoding">编码方式</param>
  /// <returns></returns>
  public static string HttpGetPageHtml(string url, string encoding)
  {
   string pageHtml = string.Empty;
   try
   {
    using (WebClient MyWebClient = new WebClient())
    {
     Encoding encode = Encoding.GetEncoding(encoding);
     MyWebClient.Headers.Add("User-Agent", "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.84 Safari/537.36");
     MyWebClient.Credentials = CredentialCache.DefaultCredentials;//获取或设置用于向Internet资源的请求进行身份验证的网络凭据
     Byte[] pageData = MyWebClient.DownloadData(url); //从指定网站下载数据
     pageHtml = encode.GetString(pageData);
    }
   }
   catch (Exception e)
   {
    
   }
   return pageHtml;
  }
  /// <summary>
  /// 从html中通过正则找到ip信息(只支持ipv4地址)
  /// </summary>
  /// <param name="pageHtml"></param>
  /// <returns></returns>
  public static string GetIPFromHtml(String pageHtml)
  {
   //验证ipv4地址
   string reg = @"(?:(?:(25[0-5])|(2[0-4]\d)|((1\d{2})|([1-9]?\d)))\.){3}(?:(25[0-5])|(2[0-4]\d)|((1\d{2})|([1-9]?\d)))";
   string ip = "";
   Match m = Regex.Match(pageHtml, reg);
   if (m.Success)
   {
    ip = m.Value;
   }
   return ip;
  }

测试(测试时间:2019年6月18日17:37:46):

  var t0_html = HttpGetPageHtml("https://www.ip.cn", "utf-8");
  var t1_html = HttpGetPageHtml("http://www.ip138.com/ips138.asp", "gbk");
  var t2_html = HttpGetPageHtml("http://www.net.cn/static/customercare/yourip.asp", "gbk");
  var t0_ip = GetIPFromHtml(t0_html);// 111.198.29.123
  var t1_ip = GetIPFromHtml(t1_html);// 111.198.29.123
  var t2_ip = GetIPFromHtml(t2_html);// 111.198.29.123

  目前这几个url地址都可以用,但不保证长久稳定,如果想稳定可靠的使用,可以使用一些收费的API接口,比如:http://user.ip138.com/ip/   

PS:这里再为大家推荐几款IP相关工具供大家参考使用:

IP地址归属地在线查询工具:
http://tools.jb51.net/aideddesign/ipcha

在线IP地址/子网掩码计算与转换工具:
http://tools.jb51.net/aideddesign/ip_net_calc

在线网络计算器|TCP/IP子网掩码计算与换算工具:
http://tools.jb51.net/aideddesign/ipcalc

更多关于C#相关内容感兴趣的读者可查看本站专题:《C#程序设计之线程使用技巧总结》、《WinForm控件用法总结》、《C#中XML文件操作技巧汇总》、《C#常见控件用法教程》、《C#数据结构与算法教程》、《C#数组操作技巧总结》及《C#面向对象程序设计入门教程》

希望本文所述对大家C#程序设计有所帮助。

您可能感兴趣的文章:
  • c#获取客户端IP地址(考虑代理)
  • 获取客户端IP地址c#/vb.net各自实现代码
  • c# 获得本地ip地址的三种方法
  • 如何用C#验证IP是否为局域网地址
  • C#获取本机IP地址(ipv4)
  • C#编程获取IP地址的方法示例
  • winform C#获得Mac地址,IP地址,子网掩码,默认网关的实例
  • C#获取路由器外网IP,MAC地址的实现代码
  • C#实现获取设置IP地址小工具
  • C#获取真实IP地址实现方法
  • C# 获取客户端IPv4地址的示例代码

centos7 设置 mysql 自启动的配置文件中 [Service] User=mysql Group=mysql,user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?

centos7 设置 mysql 自启动的配置文件中 [Service] User=mysql Group=mysql,user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?

centos7 设置 mysql 自启动的配置文件中

[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target

[Install]
WantedBy=multi-user.target

[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000
#Restart=on-failure
#RestartPreventExitStatus=1
#PrivateTmp=false

这里的

[Service]

User=mysql

Group=mysql,

user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?还是其他呢?

docker 容器下 mysql 更改 WordPress 的 site address 和 home(URL)------ 局域网

docker 容器下 mysql 更改 WordPress 的 site address 和 home(URL)------ 局域网

先简单介绍下,用 docker 安装的 WordPress,mysql 是在 docker 容器中的,并未在 Ubuntu(我把 WordPress 是安装 Ubuntu 系统上),即 WordPress 和 Ubuntu 是独立的。所以,就算 WordPress 搭建好了,Ubuntu 上也未安装 mysql。

下面来说说怎么进入 WordPress 的数据库并做修改

  • 在 <strong>docker-compose.yml</strong > 文件中查看下 mysql 的 username 和 password(按官网安装的 WordPress 是自己设置的) 其中 MYSQL_USER 和 MYSQL_PASSWORD 冒号之后的即是我们需要的 username 和 password
root@xxx:~# cat docker-compose.yml
version: ''3.3''

services:
   db:
     *****
     ******
     environment:
       ******
       ******
       MYSQL_USER: ******
       MYSQL_PASSWORD: *****

   wordpress:
     ******
     ****
    db_data:
  • 查看 mysql 的 container 名,如下,container NAME 是 my_wordpress_db_1
root@xxx:~# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                  PORTS                  NAMES
b03f13a0c99a        wordpress:latest    "docker-entrypoint.s…"   3 days ago          Up 17 hours             0.0.0.0:8000->80/tcp   my_wordpress_wordpress_1
ef196d991832        mysql:5.7           "docker-entrypoint.s…"   3 days ago          Up 6 hours              3306/tcp               my_wordpress_db_1
82cf3b926ef2        hello-world         "/hello"                 4 days ago          Exited (0) 4 days ago                          hungry_villani
  • 连接到 mysql 的镜像中
root@xxx:~# docker exec -it my_wordpress_db_1 bash
root@ef196d991832:/#
  • 登陆 mysql,username 为之前在 docker-compose.yml 中查到的用户名,在 Enter password 弹出来时,再输入密码
root@ef196d991832:/# mysql -u username -p
Enter password: 
  • 查看 database
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| wordpress          |
+--------------------+
2 rows in set (0.11 sec
  • 选中 wordpress 的 database
USE wordpress
  • 查看 wp_options 表单(数据库的 URL 存在这里。)
mysql> select * from wp_options limit 2;
+-----------+-------------+---------------------+----------+
| option_id | option_name | option_value        | autoload |
+-----------+-------------+---------------------+----------+
|         1 | siteurl     | http://0.0.0.0:8000 | yes      |
|         2 | home        | http://0.0.0.0:8000 | yes      |
+-----------+-------------+---------------------+----------+
2 rows in set (0.00 sec)
  • 更改 URL,其中 your_wordpress_url 是你的新 URL,需要的 URL
mysql> UPDATE wp_options SET option_value="your_wordpress_url" WHERE option_name="siteurl";
mysql> UPDATE wp_options SET option_value="your_wordpress_url" WHERE option_name="home";

我们今天的关于MySQL--局域网、外网访问MySQLmysql 外网访问的分享已经告一段落,感谢您的关注,如果您想了解更多关于Apache 设置本地(局域网)访问、C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析、centos7 设置 mysql 自启动的配置文件中 [Service] User=mysql Group=mysql,user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?、docker 容器下 mysql 更改 WordPress 的 site address 和 home(URL)------ 局域网的相关信息,请在本站查询。

本文标签: