本篇文章给大家谈谈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 外网访问)
- Apache 设置本地(局域网)访问
- C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析
- centos7 设置 mysql 自启动的配置文件中 [Service] User=mysql Group=mysql,user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?
- docker 容器下 mysql 更改 WordPress 的 site address 和 home(URL)------ 局域网
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安装路径中的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地址的方法。分享给大家供大家参考,具体如下:
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 自启动的配置文件中
[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 安装的 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--局域网、外网访问MySQL和mysql 外网访问的分享已经告一段落,感谢您的关注,如果您想了解更多关于Apache 设置本地(局域网)访问、C#实现获取本地内网(局域网)和外网(公网)IP地址的方法分析、centos7 设置 mysql 自启动的配置文件中 [Service] User=mysql Group=mysql,user 和 group 这边的 mysql 是指的什么?centos 的登录用户名?、docker 容器下 mysql 更改 WordPress 的 site address 和 home(URL)------ 局域网的相关信息,请在本站查询。
本文标签: