http://www.cnblogs.com/yangfengwu/p/8871464.html

先把源码和资料链接放到这里

源码链接:https://pan.baidu.com/s/1wT8KAOIzvkOXXNpkDI7E8g
提取码:1q9y

前几篇是介绍的模块建立TCP服务器,不连接路由器,然后进行通信呢,连接路由器最大的好处就是可以实现远程控制

今天呢有喜有悲,悲喜交加,板子终于开始贴片了....

今天最让人开心的事情是自己刚做的GPRS的板子和51学习的板子虽然自己马虎画错了一个地方起初也不知道...,但是嘉立创的客服今天打电话说自己那个地方有点问题,然后给自己修改了过来,,,现在感觉在嘉立创做板子就是放心,真的.不是打广告哈,感觉人家的服务就是好

现在看一下自己画的不对的地方

现在只看机械层和底层

直接一个打孔就干掉了这条线..................机械层在画板子的时候如果不注意........下次一定要时刻提醒着自己,画完板子单独看一下机械层和顶层或底层,容易忘

现在接着说

其实连接路由器就一条指令

其实应该还有配置设置自己的IP地址固定住,一会在说,咱先连接路由器,然后开启TCP,然后看一下模块的IP,然后进行通信

刚才测试发现一个问题,如果配置了连接无线了(而且保存了),那么上电后模块

那么咱们以前的程序就不能用了,,,不能是等待3s后判断有没有ready,,,,应该是复位以后一直检测有没有回复ready,超过3S没有回复就再发送一次指令,发送的指令超过3次

那么咱就重新开始

看一个就行,,,下面的都一样

    /*下面的都是一样的模子,注释就写一个*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage == )//发送指令
{
SendDataFlage = ;
printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟
P0_0 = ;//这个灯作为指示灯,发送个指令就亮,
ESP_Rst();//复位8266
} DelayMs();
if(UsartFlage == )//串口接收到数据
{
UsartFlage = ;
if(strstr(UsartReceive, "ready"))//有没有ready
{
P0_0 = ;//接收到正确的回复就灭
DelayMs();
break;
}
} Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
}

所以现在的程序

#define MAIN_C_
#include "include.h" /**
* 介绍: 主函数
* 说明: 每间隔1S发送一次温湿度数据
* 说明: 返回串口接收到的数据,发送方式为中断发送
* 说明: None
* 说明: None
* 支持: QQ946029359 --群 607064330
* 淘宝: https://shop411638453.taobao.com/
* 作者: 小五
**/ int Cnt = ;
unsigned char CntCnt = ;
unsigned char SendDataFlage = ; unsigned char ConnectID = ;
unsigned char i=;
unsigned char SendDataValue[]={0xaa,0x55};
int ReadDHT11delay = ;//设置多少时间读一次DHT11;
void main()
{
InitUART();
InitTimer0(); start: /*下面的都是一样的模子,注释就写一个*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage == )//发送指令
{
SendDataFlage = ;
printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟
P0_0 = ;//这个灯作为指示灯,发送个指令就亮,
ESP_Rst();//复位8266
} DelayMs();
if(UsartFlage == )//串口接收到数据
{
UsartFlage = ;
if(strstr(UsartReceive, "ready"))//有没有ready
{
P0_0 = ;//接收到正确的回复就灭
DelayMs();
break;
}
} Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
} } /*配置连接路由器*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CWJAP_DEF=\"qqqqq\",\"11223344\"\r\n");//连接路由器
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
} Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} /*配置模式*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CWMODE_DEF=3\r\n");//AP+Station
P0_0 = ;
}
DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
}
Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} /*多连接*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CIPMUX=1\r\n");//启动多连接
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
}
Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
}
/*创建服务器*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CIPSERVER=1,1001\r\n");//创建服务器
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
}
Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} /*让小灯闪一闪,算是说明正确执行了把*/
P0_0 = ;
DelayMs();
P0_0 = ;
DelayMs();
P0_0 = ;
DelayMs();
P0_0 = ;
DelayMs();
P0_0 = ; while()
{ if(TimeCnt>=)
{
TimeCnt = ;
DHT11_Receive();
} if(UsartFlage == )//返回接收的数据
{
UsartFlage = ; for(i=;i<;i++)//找到开始的数据位置,有的固件数据前头有换行,有的没有
{
if(UsartReceive[i]=='+' && UsartReceive[i+]=='I'&& UsartReceive[i+]=='P')//判断数据的头
{
ConnectID = UsartReceive[i+];//得到是几号连接的
if(ConnectID>=0x30 && ConnectID<=0x34)//得到的ID号有没有越界
{
for(i=;i<;i++)//找到 : 在哪里,才知道真实数据在哪里
{
if(UsartReceive[i] == ':')
{
if(UsartReceive[i+]==0xaa && UsartReceive[i+]==0x55)
{
switch(UsartReceive[i+])
{
case 0x01: SendDataValue[] = 0x01;
SendDataValue[] = DHT11Data[];
SendDataValue[] = DHT11Data[];
ESPSendData(ConnectID-0x30,,SendDataValue,);
break;//发送温湿度数据
case 0x02: if(UsartReceive[i+] == 0x00)
{
P0_0 = ;
}
else if(UsartReceive[i+] == 0xff)
{
P0_0 = ;
}
break;
default:break;
}
break;//结束for(i=6;i<15)
}
}
} break;//结束for(i=0;i<10;i++)
}
}
} } }
}

多加了一个指令(在复位后执行)

对了\"  在前面介绍了哈  就是代表"

程序下进去了,现在看一下自己的路由器列表

现在测试通信

用咱做的TCP客户端测试

既然连接路由器了,就可以实现远程了

先用花生壳,,不知道还能不能用,花了6块钱都买了一年了.....

详细的购买花生壳过程,请参考我的这篇文章

http://www.cnblogs.com/yangfengwu/p/7736296.html#3941866

先映射

对了说一下,其实直接连接模块的无线也是可以通信的....

现在测试C#TCP客户端

现在用花生壳连接

看来是解析域名出了问题直接百度

咱试一试

可以啦.....

接着再修改一下单片机的程序,8266连接路由器之后是不是因为自动分配的IP,所以对于咱来说是不是不方便哈,如果IP地址变了,,,还要查看,然后花生壳还要跟着修改,,,

现在咱固定模块的IP

两种方式一种是用模块的指令,另一种是在路由器里面修改

咱先用指令修改

我先用串口助手配置一下看看回的内容

现在做单片机程序..其实就是加一个指令

/*配置连接路由器后分得的IP地址是多少*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
} Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
}

现在也设置一下花生壳

咱用手机远程连接一下

现在用路由器修改

咱先把程序修改的屏蔽掉,

    /*配置连接路由器后分得的IP地址是多少*/
// Cnt = 0;
// CntCnt = 0;
// SendDataFlage = 1;
// while(1)
// {
// if(SendDataFlage)
// {
// SendDataFlage = 0;
// printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
// P0_0 = 1;
// }
//
// DelayMs(1);
// if(UsartFlage == 1)
// {
// UsartFlage = 0;
// if(strstr(UsartReceive, "OK"))
// {
// P0_0 = 0;
// DelayMs(500);
// break;
// }
// }
//
// Cnt ++;
// if(Cnt>=3000)//每间隔3S发送一次数据
// {
// SendDataFlage = 1;//允许发送数据
// Cnt = 0;
// CntCnt++;
// }
// if(CntCnt>=3)//超过三次重新开始
// {
// CntCnt = 0;
// Cnt = 0;
// goto start;
// }
// }

噢噢噢噢噢噢噢知道原因了

可以先恢复出厂设置

不过模块有问题了.................

哦哦哦哦哦知道原因了....要先设置模式默认AP模式是不可以连接路由器的................以前的程序全部有BUG...................

#define MAIN_C_
#include "include.h" /**
* 介绍: 主函数
* 说明: 每间隔1S发送一次温湿度数据
* 说明: 返回串口接收到的数据,发送方式为中断发送
* 说明: None
* 说明: None
* 支持: QQ946029359 --群 607064330
* 淘宝: https://shop411638453.taobao.com/
* 作者: 小五
**/ int Cnt = ;
unsigned char CntCnt = ;
unsigned char SendDataFlage = ; unsigned char ConnectID = ;
unsigned char i=;
unsigned char SendDataValue[]={0xaa,0x55};
int ReadDHT11delay = ;//设置多少时间读一次DHT11;
void main()
{
InitUART();
InitTimer0(); start: /*下面的都是一样的模子,注释就写一个*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage == )//发送指令
{
SendDataFlage = ;
printf("8266RST\r\n");//这个不是什么指令,我先用串口调试助手模拟
P0_0 = ;//这个灯作为指示灯,发送个指令就亮,
ESP_Rst();//复位8266
} DelayMs();
if(UsartFlage == )//串口接收到数据
{
UsartFlage = ;
if(strstr(UsartReceive, "ready"))//有没有ready
{
P0_0 = ;//接收到正确的回复就灭
DelayMs();
break;
}
} Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} /*配置模式*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CWMODE_DEF=3\r\n");//AP+Station
P0_0 = ;
}
DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
}
Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} // /*配置连接路由器后分得的IP地址是多少*/
// Cnt = 0;
// CntCnt = 0;
// SendDataFlage = 1;
// while(1)
// {
// if(SendDataFlage)
// {
// SendDataFlage = 0;
// printf("AT+CIPSTA_DEF=\"192.168.1.106\",\"192.168.1.1\",\"255.255.255.0\"\r\n");
// P0_0 = 1;
// }
//
// DelayMs(1);
// if(UsartFlage == 1)
// {
// UsartFlage = 0;
// if(strstr(UsartReceive, "OK"))
// {
// P0_0 = 0;
// DelayMs(500);
// break;
// }
// }
//
// Cnt ++;
// if(Cnt>=3000)//每间隔3S发送一次数据
// {
// SendDataFlage = 1;//允许发送数据
// Cnt = 0;
// CntCnt++;
// }
// if(CntCnt>=3)//超过三次重新开始
// {
// CntCnt = 0;
// Cnt = 0;
// goto start;
// }
// } /*配置连接路由器*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CWJAP_DEF=\"qqqqq\",\"11223344\"\r\n");//连接路由器
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
} Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} /*多连接*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CIPMUX=1\r\n");//启动多连接
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
}
Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
}
/*创建服务器*/
Cnt = ;
CntCnt = ;
SendDataFlage = ;
while()
{
if(SendDataFlage)
{
SendDataFlage = ;
printf("AT+CIPSERVER=1,1001\r\n");//创建服务器
P0_0 = ;
} DelayMs();
if(UsartFlage == )
{
UsartFlage = ;
if(strstr(UsartReceive, "OK"))
{
P0_0 = ;
DelayMs();
break;
}
}
Cnt ++;
if(Cnt>=)//每间隔3S发送一次数据
{
SendDataFlage = ;//允许发送数据
Cnt = ;
CntCnt++;
}
if(CntCnt>=)//超过三次重新开始
{
CntCnt = ;
Cnt = ;
goto start;
}
} /*让小灯闪一闪,算是说明正确执行了把*/
P0_0 = ;
DelayMs();
P0_0 = ;
DelayMs();
P0_0 = ;
DelayMs();
P0_0 = ;
DelayMs();
P0_0 = ; while()
{ if(TimeCnt>=)
{
TimeCnt = ;
DHT11_Receive();
} if(UsartFlage == )//返回接收的数据
{
UsartFlage = ; for(i=;i<;i++)//找到开始的数据位置,有的固件数据前头有换行,有的没有
{
if(UsartReceive[i]=='+' && UsartReceive[i+]=='I'&& UsartReceive[i+]=='P')//判断数据的头
{
ConnectID = UsartReceive[i+];//得到是几号连接的
if(ConnectID>=0x30 && ConnectID<=0x34)//得到的ID号有没有越界
{
for(i=;i<;i++)//找到 : 在哪里,才知道真实数据在哪里
{
if(UsartReceive[i] == ':')
{
if(UsartReceive[i+]==0xaa && UsartReceive[i+]==0x55)
{
switch(UsartReceive[i+])
{
case 0x01: SendDataValue[] = 0x01;
SendDataValue[] = DHT11Data[];
SendDataValue[] = DHT11Data[];
ESPSendData(ConnectID-0x30,,SendDataValue,);
break;//发送温湿度数据
case 0x02: if(UsartReceive[i+] == 0x00)
{
P0_0 = ;
}
else if(UsartReceive[i+] == 0xff)
{
P0_0 = ;
}
break;
default:break;
}
break;//结束for(i=6;i<15)
}
}
} break;//结束for(i=0;i<10;i++)
}
}
} } }
}

花生壳刚才检测原因关了,现在重新用花生壳映射

电脑端就不测试了,,,

其实这篇就改了一下单片机和C#的程序

今天...以前的源码全有BUG.............唉

补充:

如果路由器不能上网,可以这样

注意点:

路由器桥接手机的WIFI信号后,如果没有注意到路由器分得的IP就登录不进路由器了,因为我们登录不进路由器,所以映射的时候怎么知道WIFI的IP地址,咱们可以设置WiFi固定住IP,但是网关和子网掩码呢可以看电脑的

然后花生壳映射

另一个手机或者本机连接这个就可以

下一篇链接

https://www.cnblogs.com/yangfengwu/p/8970580.html

https://yq.aliyun.com/articles/585610

10-51单片机ESP8266学习-AT指令(ESP8266连接路由器,建立TCP服务器,分别和C#TCP客户端和AndroidTCP客户端通信+花生壳远程通信)的更多相关文章

  1. 11-51单片机ESP8266学习-AT指令(ESP8266作为TCP客户端,连接TCP服务器,用串口调试助手和手机TCP调试助手测试)

    写完题目刚想起来一件事情,如果手机作为客户端(不连接路由器的情况下),手机连接模块的无线会分配一个IP地址,,,这个IP地址事先我也不知道....我先看看AT指令里面有没有一个指令可以打印一下连接自己 ...

  2. 2-51单片机ESP8266学习-AT指令(开发板51单片机自动冷启动下载原理)

    前言:了解就行,不必深究 上一篇链接 http://www.cnblogs.com/yangfengwu/p/8720148.html 源码链接:https://pan.baidu.com/s/1wT ...

  3. 3-51单片机ESP8266学习-AT指令(学会刷固件)

    前言:体验一下刷固件(给单片机更新程序) 上一篇链接  http://www.cnblogs.com/yangfengwu/p/8757036.html 源码链接:https://pan.baidu. ...

  4. 1-51单片机ESP8266学习-AT指令(开发板介绍)

    51单片机+ESP8266开发教程(AT指令篇) 开发板资源分布: 开发板部分原理图: 1--通信下载 2--51单片机 3--ESP8266(WIFI模块) 4--DHT11(温湿度传感器) 5-- ...

  5. 5-51单片机ESP8266学习-AT指令(8266TCP服务器--用手机TCP调试助手发信息给单片机控制小灯的亮灭)

    http://www.cnblogs.com/yangfengwu/p/8759294.html 源码链接:https://pan.baidu.com/s/1wT8KAOIzvkOXXNpkDI7E8 ...

  6. 8-51单片机ESP8266学习-AT指令(单片机采集温湿度数据通过8266发送给C#TCP客户端显示)

    http://www.cnblogs.com/yangfengwu/p/8785516.html 先写单片机端的程序 先把源码和资料链接放到这里 链接: https://pan.baidu.com/s ...

  7. 4-51单片机ESP8266学习-AT指令(测试TCP服务器--使用串口调试助手--不连接路由器)

    上一篇连接  http://www.cnblogs.com/yangfengwu/p/8757513.html 源码链接:https://pan.baidu.com/s/1wT8KAOIzvkOXXN ...

  8. 12,13,14节-51单片机ESP8266学习-AT指令(暂停更新)需要整理

    从这一节开始,以视频加源码的形式,后期视频和程序将放在链接中 资料链接 链接: https://pan.baidu.com/s/1jpHZjW_7pQKNfN9G4B6ZjA     密码:nhn3  ...

  9. 9-51单片机ESP8266学习-AT指令(单片机采集温湿度数据通过8266发送给AndroidTCP客户端显示)

    http://www.cnblogs.com/yangfengwu/p/8798512.html 补充:今天答应了一个朋友写一下如果单片机发过的是字符串应该怎么解析,答应了今天写,哦哦哦是明天了,闲话 ...

随机推荐

  1. Js调试中不得不知的Console

    在js调试中,大部分的前端人员都是采用console.log()方法来打印出调试的数据,但是很多人都不知道console这个对象有很多很实在的方法,本文就来介绍一下这些方法的使用. 一.console ...

  2. filter(ele)过滤数组

    filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素. 例如,在一个Array中,删掉偶数,只保留奇数,可以这么写: function remove(arr) { l ...

  3. LeanCloud云引擎相关问题

    (1).Windows 用户可以在 Github releases 页面 根据操作系统版本下载最新的 32 位 或 64 位 msi 安装包进行安装,安装成功之后在 Windows 命令提示符(或 P ...

  4. 英雄无敌HoMM3-死亡阴影SOD-神之苏醒WOG-封神NABI-MOD等相关文件

    英雄无敌HoMM3:死亡阴影SOD 英雄无敌3之死亡阴影(Heroes of Might and Magic III: Shadow of Death,简记为HoMM III: SOD)发行于1999 ...

  5. React.js 新手教程

    正如你能从标题猜到的,这篇文章的目标是给那些有很少编程经验的读者的.比如,像我这样的人:因为迄今为止,我才探索了编程世界6个月.所以,这将是一篇新手村教程! 你只需要拥有对 HTML 和 CSS 的理 ...

  6. (后台)详细了解java中的null(转)

    转自CSDN: 相信大家对于NullPointException 这个让人又爱又恨的不陌生吧..对于Java程序员来说,null是令人头痛的东西.时常会受到空指针异常(NPE)的骚扰 .今天我们就来谈 ...

  7. Scrum敏捷开发沉思录

    计算机科学的诞生,是世人为了用数字手段解决实际生活中的问题.随着时代的发展,技术的进步,人们对于现实世界中的问题理解越来越深刻,描述也越来越抽象,于是对计算机软件的需求也越来越高,越来越复杂,变化也越 ...

  8. 03-13_WLST导航和定位MBean

    本文重点:WLST导航和定位MBean     MBean切换图 如上:红色的字体表示切换的命令.ls和cd是在当前树下切换,其他命令是在不同树之间切换. 其中: DomainMBeanServer有 ...

  9. Java同步、异步区别

    一.概念: 1.同步:所有的操作都做完,才返回给用户.这样用户在线等待的时间太长,给用户一种卡死了的感觉(就是系统迁移中,点击了迁移,界面就不动了,但是程序还在执行,卡死了的感觉).这种情况下,用户不 ...

  10. CentOS 7下systemd是如何stop mysql服务的

      [背景] 有同事在研究mongo的服务启动方式,讨论到mysql5.7的服务管理时一起做了下面测试. MySQL5.7是用systemd来管理service的,它的配置文件/usr/lib/sys ...