
一、现象
Linux关机或重启时提示A stop job is running for ..
导致关机慢。
二、解决方法
编辑/etc/systemd/system.conf
修改下面两个变量为:
DefaultTimeoutStartSec=10s
DefaultTimeoutStopSec=10s
执行:systemctl daemon-reload
来自:https://blog.csdn.net/penge199761/article/details/79136826
Linux关机或重启时提示A stop job is running for ..
导致关机慢。
二、解决方法
编辑/etc/systemd/system.conf
修改下面两个变量为:
DefaultTimeoutStartSec=10s
DefaultTimeoutStopSec=10s
执行:systemctl daemon-reload
来自:https://blog.csdn.net/penge199761/article/details/79136826
[实践OK]用c语言的语法逻辑进行判断是不是质数的重构逻辑学习。
Unix/LinuxC技术 jackxiang 2021-1-14 10:53
质数定义:只有1和它本身两个约数,除此之外再没有其它约数。
示例1:
make zs
cc zs.c -o zs
#./zs
质数
示例2:
for循环介入:
引入scanf:
#./zs
5
质数
#./zs
6
合数
打印出约数:
#./zs
5
质数
#./zs
6
2 3 合数
更快一点,引入break:
#./zs
6
合数
#./zs
1000
合数
任一大于2的偶数都可以写成两个质数之和,采用部分穷举法,可以从1-100,1-10000啥的,但无法穷举所有:
#./zs
100
4=2+2
6=3+3
8=3+5
10=3+7
12=5+7
14=3+11
16=3+13
18=5+13
20=3+17
22=3+19
24=5+19
26=3+23
28=5+23
30=7+23
32=3+29
34=3+31
36=5+31
...
示例1:
make zs
cc zs.c -o zs
#./zs
质数
示例2:
for循环介入:
引入scanf:
#./zs
5
质数
#./zs
6
合数
打印出约数:
#./zs
5
质数
#./zs
6
2 3 合数
更快一点,引入break:
#./zs
6
合数
#./zs
1000
合数
任一大于2的偶数都可以写成两个质数之和,采用部分穷举法,可以从1-100,1-10000啥的,但无法穷举所有:
#./zs
100
4=2+2
6=3+3
8=3+5
10=3+7
12=5+7
14=3+11
16=3+13
18=5+13
20=3+17
22=3+19
24=5+19
26=3+23
28=5+23
30=7+23
32=3+29
34=3+31
36=5+31
...
[实践OK]关于go进行多进程通讯的等待子进程问题学习浅显研究。
Php/Js/Shell/Go jackxiang 2021-1-4 18:53
背景:有一篇朋友圈说是一个k8s里面Server的Pod销毁上报Zookeeper出现IP地址连接还是原来的,用到了zk的watcher,理论上不应该这样,于是查来查去,其大体意思就是说用了Go的多进程,有一个进程去读取配置了,因为配置还是老的,而用到了Go的多进程,于是文末那代码,我看了下,简单,但不明白,于是顺藤摸瓜学习一下这个rsync的原理。
——————————
#tree -L 2 .|grep go
├── loop.go
├── pipe.go
├── waitgrouppointer.go
└── wg.go
#cat loop.go
package main
import (
"fmt"
//"time"
)
func main(){
for i := 0; i < 100 ; i++{
go fmt.Println(i)
}
//time.Sleep(time.Second)
}
这个说是运行太快,子进程没输出主进程就退了,啥也不输出。
#cat pipe.go
package main
import (
"fmt"
//"time"
)
func main() {
c := make(chan bool, 100)
for i := 0; i < 100; i++ {
go func(i int) {
fmt.Println(i)
c <- true
}(i)
}
for i := 0; i < 100; i++ {
<-c
}
}
这个说是管道要是上万,会耗尽系统管道资源。
#cat waitgroup.go
package main
import (
"fmt"
"sync"
//"time"
)
func main() {
wg := sync.WaitGroup{}
wg.Add(100)
for i := 0; i < 100; i++ {
go func(i int) {
fmt.Println(i)
wg.Done()
}(i)
}
wg.Wait()
}
这个说是挺好的,因为它用到了原子加减法,这里好像C语言也有类似的函数,
再就是说它是用来阻塞方进程的,WaitGroup 对象内部有一个计数器,最初从0开始,它有三个方法:Add(), Done(), Wait() 用来控制计数器的数量。Add(n) 把计数器设置为n ,Done() 每次把计数器-1 ,wait() 会阻塞代码的运行,直到计数器地值减为0。
这里首先把wg 计数设置为100, 每个for循环运行完毕都把计数器减一,主函数中使用Wait() 一直阻塞,直到wg为零——也就是所有的100个for循环都运行完毕。相对于使用管道来说,WaitGroup 轻巧了许多。
最后,如果要搞裂成函数,得用引用传入,指针变量:
WaitGroup对象不是一个引用类型
WaitGroup对象不是一个引用类型,在通过函数传值的时候需要使用地址:
#cat waitgrouppointer.go
package main
import (
"fmt"
"sync"
//"time"
)
func main() {
wg := sync.WaitGroup{}
wg.Add(100)
for i := 0; i < 100; i++ {
go f(i, &wg)
}
wg.Wait()
}
// 一定要通过指针传值,不然进程会进入死锁状态
func f(i int, wg *sync.WaitGroup) {
fmt.Println(i)
wg.Done()
}
以上来自:https://blog.csdn.net/u013474436/article/details/88749749
溯源来自:https://mp.weixin.qq.com/s/s9G6yDqfeFepbKT6DJASng
#cat wg.go
package main
import (
"fmt"
"sync"
)
func main() {
ok := true
for i := 0; i <1000; i ++ {
var arr []int
wg := sync.WaitGroup{}
for j := 0; j <2; j ++ {
wg.Add(1)
go func() {
defer wg.Done()
arr = append(arr, i)
}()
}
wg.Wait()
if len(arr) < 2 {
fmt.Printf("error:%d \n", i)
ok = false
break
}
}
if ok {
fmt.Println("ok")
}
}
阅读全文
——————————
#tree -L 2 .|grep go
├── loop.go
├── pipe.go
├── waitgrouppointer.go
└── wg.go
#cat loop.go
package main
import (
"fmt"
//"time"
)
func main(){
for i := 0; i < 100 ; i++{
go fmt.Println(i)
}
//time.Sleep(time.Second)
}
这个说是运行太快,子进程没输出主进程就退了,啥也不输出。
#cat pipe.go
package main
import (
"fmt"
//"time"
)
func main() {
c := make(chan bool, 100)
for i := 0; i < 100; i++ {
go func(i int) {
fmt.Println(i)
c <- true
}(i)
}
for i := 0; i < 100; i++ {
<-c
}
}
这个说是管道要是上万,会耗尽系统管道资源。
#cat waitgroup.go
package main
import (
"fmt"
"sync"
//"time"
)
func main() {
wg := sync.WaitGroup{}
wg.Add(100)
for i := 0; i < 100; i++ {
go func(i int) {
fmt.Println(i)
wg.Done()
}(i)
}
wg.Wait()
}
这个说是挺好的,因为它用到了原子加减法,这里好像C语言也有类似的函数,
再就是说它是用来阻塞方进程的,WaitGroup 对象内部有一个计数器,最初从0开始,它有三个方法:Add(), Done(), Wait() 用来控制计数器的数量。Add(n) 把计数器设置为n ,Done() 每次把计数器-1 ,wait() 会阻塞代码的运行,直到计数器地值减为0。
这里首先把wg 计数设置为100, 每个for循环运行完毕都把计数器减一,主函数中使用Wait() 一直阻塞,直到wg为零——也就是所有的100个for循环都运行完毕。相对于使用管道来说,WaitGroup 轻巧了许多。
最后,如果要搞裂成函数,得用引用传入,指针变量:
WaitGroup对象不是一个引用类型
WaitGroup对象不是一个引用类型,在通过函数传值的时候需要使用地址:
#cat waitgrouppointer.go
package main
import (
"fmt"
"sync"
//"time"
)
func main() {
wg := sync.WaitGroup{}
wg.Add(100)
for i := 0; i < 100; i++ {
go f(i, &wg)
}
wg.Wait()
}
// 一定要通过指针传值,不然进程会进入死锁状态
func f(i int, wg *sync.WaitGroup) {
fmt.Println(i)
wg.Done()
}
以上来自:https://blog.csdn.net/u013474436/article/details/88749749
溯源来自:https://mp.weixin.qq.com/s/s9G6yDqfeFepbKT6DJASng
#cat wg.go
package main
import (
"fmt"
"sync"
)
func main() {
ok := true
for i := 0; i <1000; i ++ {
var arr []int
wg := sync.WaitGroup{}
for j := 0; j <2; j ++ {
wg.Add(1)
go func() {
defer wg.Done()
arr = append(arr, i)
}()
}
wg.Wait()
if len(arr) < 2 {
fmt.Printf("error:%d \n", i)
ok = false
break
}
}
if ok {
fmt.Println("ok")
}
}

[实践成功]go tcp tcpclient编码
Php/Js/Shell/Go jackxiang 2020-12-30 16:55
Server:echoServer.go
Client:echoClient.go
jackXiang@localhost ~/golearning ./echoClient
jack
read from socket:
jack
xiang
read from socket:
xiang
Q:果然Ok,两个问题探讨下:
1) ip4 := net.ParseIP(ADDR).To4()
sa := &syscall.SockaddrInet4{Port: PORT}
copy(sa.Addr[:], ip4) #这个sa.Addr[:] 冒号啥写法呢?
2)for { 这里面是epoll 吗?}
A:
1.
copy(sa.Addr[:], ip4) #这个sa.Addr[:] 冒号啥写法呢?
sa.Addr 是一个数组,
sa.Addr[:] 将这个数组临时转为切片,底层数组指向sa.Addr数组
方便copy进行切片复制
2. 就是个for{}死循环,防止代码往下执行
来自:
https://mp.weixin.qq.com/s/dRADQ5kUCT80dX7oEAAXyA
https://mp.weixin.qq.com/s/kFHw73w_IIqjKeicesCpZw
Client:echoClient.go
jackXiang@localhost ~/golearning ./echoClient
jack
read from socket:
jack
xiang
read from socket:
xiang
Q:果然Ok,两个问题探讨下:
1) ip4 := net.ParseIP(ADDR).To4()
sa := &syscall.SockaddrInet4{Port: PORT}
copy(sa.Addr[:], ip4) #这个sa.Addr[:] 冒号啥写法呢?
2)for { 这里面是epoll 吗?}
A:
1.
copy(sa.Addr[:], ip4) #这个sa.Addr[:] 冒号啥写法呢?
sa.Addr 是一个数组,
sa.Addr[:] 将这个数组临时转为切片,底层数组指向sa.Addr数组
方便copy进行切片复制
2. 就是个for{}死循环,防止代码往下执行
来自:
https://mp.weixin.qq.com/s/dRADQ5kUCT80dX7oEAAXyA
https://mp.weixin.qq.com/s/kFHw73w_IIqjKeicesCpZw
[要实践么]macOS Big Sur 可写模式挂载root
Unix/LinuxC技术 jackxiang 2020-11-26 10:27
背景:[实践OK]Macbook 升级到catalina 后的一些/data目录不见了等问题
:https://jackxiang.com/post/10397/,现在升级后,这个玩法被苹果给屏蔽更深了,怎么办?有人做这个,我不太敢接着搞下去了:
Big Sur 新增了 Signed System Volume 机制,对系统所在的 APFS Volume 增加了更多的保护
Reboot into recovery mode and run:重启mac,按住Command+R,等到系统进入安全模式。
命令 csrutil disable ,sur还得加上这个:
csrutil authenticated-root disable
Reboot back into MacOS #正常重启进入系统
Find your root mount's device - run mount and chop off the last s, e.g. if your root is /dev/disk1s5s1, you'll mount /dev/disk1s5
Create a new directory, for example ~/mount
Run:sudo mount -o nobrowse -t apfs /dev/disk1s5 ~/mount ,我这想:sudo mount -o nobrowse -t apfs /dev/disk1s5 /var/data
/dev/disk1s5s1 :https://iosre.com/t/big-sur/18051
升级到Big Sur后,以写模式挂载root报错(SIP已disable)
sudo mount -uw /
mount_apfs: volume could not be mounted: Permission denied
mount: / failed with 66
Big Sur 新增了 Signed System Volume 机制,对系统所在的 APFS Volume 增加了更多的保护
Reboot into recovery mode and run:
csrutil authenticated-root disable
Reboot back into MacOS
Find your root mount's device - run mount and chop off the last s, e.g. if your root is /dev/disk1s5s1, you'll mount /dev/disk1s5
Create a new directory, for example ~/mount
Run:sudo mount -o nobrowse -t apfs /dev/disk1s5 ~/mount
Modify the files under the mounted directory
Run:sudo bless --folder MOUNT_PATH/System/Library/CoreServices --bootefi --create-snapshot
Reboot your system, and the changes will take place
缺点:
修改后,无法再启用SSV机制,但是可以启用SIP机制,因为系统已修改,导致签名不一致,若启用SSV,则校验失败,报错禁止启动。
csrutil enable
csrutil authenticated-root disable
Big Sur 引入的 Signed System Volume 机制会给 System APFS Volume 的每个文件 /文件夹都设置一份 hash,在 bootloader 启动后,加载内核前会进行完整性校验,校验不通过的话会拒绝引导,并提示用户重装 macOS 。使用 mount 查看挂载点会发现 /多了个 sealed 标志。系统默认会从 SSV snapshot 启动,对用户无感知。
Big Sur’s Signed System Volume: added security protection
来自:https://www.quwenqing.com/archives/1597.html
:https://jackxiang.com/post/10397/,现在升级后,这个玩法被苹果给屏蔽更深了,怎么办?有人做这个,我不太敢接着搞下去了:
Big Sur 新增了 Signed System Volume 机制,对系统所在的 APFS Volume 增加了更多的保护
Reboot into recovery mode and run:重启mac,按住Command+R,等到系统进入安全模式。
命令 csrutil disable ,sur还得加上这个:
csrutil authenticated-root disable
Reboot back into MacOS #正常重启进入系统
Find your root mount's device - run mount and chop off the last s, e.g. if your root is /dev/disk1s5s1, you'll mount /dev/disk1s5
Create a new directory, for example ~/mount
Run:sudo mount -o nobrowse -t apfs /dev/disk1s5 ~/mount ,我这想:sudo mount -o nobrowse -t apfs /dev/disk1s5 /var/data
/dev/disk1s5s1 :https://iosre.com/t/big-sur/18051
升级到Big Sur后,以写模式挂载root报错(SIP已disable)
sudo mount -uw /
mount_apfs: volume could not be mounted: Permission denied
mount: / failed with 66
Big Sur 新增了 Signed System Volume 机制,对系统所在的 APFS Volume 增加了更多的保护
Reboot into recovery mode and run:
csrutil authenticated-root disable
Reboot back into MacOS
Find your root mount's device - run mount and chop off the last s, e.g. if your root is /dev/disk1s5s1, you'll mount /dev/disk1s5
Create a new directory, for example ~/mount
Run:sudo mount -o nobrowse -t apfs /dev/disk1s5 ~/mount
Modify the files under the mounted directory
Run:sudo bless --folder MOUNT_PATH/System/Library/CoreServices --bootefi --create-snapshot
Reboot your system, and the changes will take place
缺点:
修改后,无法再启用SSV机制,但是可以启用SIP机制,因为系统已修改,导致签名不一致,若启用SSV,则校验失败,报错禁止启动。
csrutil enable
csrutil authenticated-root disable
Big Sur 引入的 Signed System Volume 机制会给 System APFS Volume 的每个文件 /文件夹都设置一份 hash,在 bootloader 启动后,加载内核前会进行完整性校验,校验不通过的话会拒绝引导,并提示用户重装 macOS 。使用 mount 查看挂载点会发现 /多了个 sealed 标志。系统默认会从 SSV snapshot 启动,对用户无感知。
Big Sur’s Signed System Volume: added security protection
来自:https://www.quwenqing.com/archives/1597.html
背景:Chrome您的连接不是私密连接解决办法--一个比较实用的技巧分享,有的勾选确认,发现没有勾选按钮。怎么办?
方法:解决:就是在当前页面用键盘输入 thisisunsafe ,不是在地址栏输入,就直接敲键盘就行了,页面即会自动刷新进入网页。
阅读全文
方法:解决:就是在当前页面用键盘输入 thisisunsafe ,不是在地址栏输入,就直接敲键盘就行了,页面即会自动刷新进入网页。

Mac / OS X 如何快速显示桌面:F4
Mac苹果电脑怎么设置Launchpad快捷键?F11
=============================
Mac / OS X 如何快速显示桌面(Desktop)?
https://www.zhihu.com/question/21448506
【收藏】Mac苹果电脑怎么设置Launchpad快捷键?
来自:https://www.zhihu.com/question/21448506
Mac苹果电脑怎么设置Launchpad快捷键?F11
=============================
Mac / OS X 如何快速显示桌面(Desktop)?
https://www.zhihu.com/question/21448506
【收藏】Mac苹果电脑怎么设置Launchpad快捷键?
来自:https://www.zhihu.com/question/21448506
[实践OK]协程 shell_exec 如何捕获标准错误流
Swoole专题研究 jackxiang 2020-11-3 14:30
问题:用Co\System::exec()执行了一个不存在的命令时,错误信息会直接打印到屏幕,而不是返回错误信息。
怎么办:实际上Swoole提供的System::exec()行为上与PHP的shell_exec是完全一致的,我们写一个shell_exec的同步阻塞版本,执行后发现同样拿不到标准错误流输出的内容,会被直接打印到屏幕。
答案: 使用proc_open+hook实现。
现象:
==================================================================
#php tt.php
PHP Warning: shell_exec() has been disabled for security reasons in /data/www/testswoole/tt.php on line 2
NULL
估计整成错误输出了,于是用:
php tt.php >/dev/null 2>&1
果然,怎么办?加入管道,将此错误指向新的文件描述符。
前置:打开php.ini里面的proc_open禁用函数。
#cat t.php
#php t.php
array(3) {
[0]=>
resource(4) of type (stream)
[1]=>
resource(5) of type (stream)
[2]=>
resource(6) of type (stream)
}
string(31) "sh: unknown: command not found
"
command returned 32512
代码来自rango:https://mp.weixin.qq.com/s/z7SPy-tV3hsQqLXZ-tKlZw
怎么办:实际上Swoole提供的System::exec()行为上与PHP的shell_exec是完全一致的,我们写一个shell_exec的同步阻塞版本,执行后发现同样拿不到标准错误流输出的内容,会被直接打印到屏幕。
答案: 使用proc_open+hook实现。
现象:
==================================================================
#php tt.php
PHP Warning: shell_exec() has been disabled for security reasons in /data/www/testswoole/tt.php on line 2
NULL
估计整成错误输出了,于是用:
php tt.php >/dev/null 2>&1
果然,怎么办?加入管道,将此错误指向新的文件描述符。
前置:打开php.ini里面的proc_open禁用函数。
#cat t.php
#php t.php
array(3) {
[0]=>
resource(4) of type (stream)
[1]=>
resource(5) of type (stream)
[2]=>
resource(6) of type (stream)
}
string(31) "sh: unknown: command not found
"
command returned 32512
代码来自rango:https://mp.weixin.qq.com/s/z7SPy-tV3hsQqLXZ-tKlZw
背景:央视网发声明:“中央电视台网”严重侵权,已向相关部门举报,这是不可辩驳的事实。但是我对这个中文域名技术实现的原理有点兴趣,于是问一下技术人员和自己查了下。了解到早些年关于中文域名被好多网络公司买的如火如荼,也养活了好多网络公司多少年,在这里我们不讨论中文是否有价值,我们这里讨论一下中文域名的工作原理,下面是RFC文件。
RFC3490
(Request For Comments (RFC),是一系列以编号排定的文件。文件收集了有关因特网相关资讯,以及UNIX和因特网社群的软件文件。目前RFC文件是由Internet Society(ISOC)所赞助发行。)
Internationalizing Domain Names in Applications (IDNA)
用户输入国际化域名后,由应用程序完成本地码到Unicode编码的转换,然后再完成Unicode编码到7位Punycode编码的转换,然后由解析器(Resolver)发给DNS服务器进行解析。DNS服务器里存储的不是八位编码的Unicode字符串,而是经过Punycode算法处理的7位编码字符串。
IDNA中应用程序对IDN进行ToASCII和ToUnicode操作的时候会调用Punycode算法完成七位和八位数据的转换操作。
ToASCII和ToUnicode过程参见RFC3490 4.1和4.2小节
一个八位Unicode表示的域名字段的字符串将会被转化成为七位字母数字表示的字符串,并添加前缀“xn--”以便与其他英文域名区分,表示这个域名字段是IDN。
按照上面的解释,我们以侵权域名“中央电视台网.网址”为例,软件环境为ie7简体中文版
中央电视台网.网址. ==>Punycode编码转换. ===> Punycode编码转换后:
xn--fiq53l90e917a0tk4ip.xn--ses554g

www.中央电视台网.网址. =怎么编码变为下面这串的呢?=>
http://www.xn--fiq53l90e917a0tk4ip.xn--ses554g/
于是在浏览器里输入这个“中央电视台网”侵权事宜的域名:
www.中央电视台网.网址. =怎么编码变为下面这串的呢?===我们在ie7的状态栏中看到==》
http://www.xn--fiq53l90e917a0tk4ip.xn--ses554g/
在ie6的时代,是不支持中文域名的使用的,为什么现在ie7就支持了呢,我们理解一下RFC3490的内容
“由应用程序完成...”,“程序”这里是指ie7,或者更高浏览器,或者其它浏览器,“完成”指的是浏览器中内置了Punycode的转换,意思是浏览器里面主动加入了中文域名自动转码。ie7简体中文内置了自动转码工具,其它的就不知道了,说白了就是浏览器厂商将这个功能加上去,我们就能用,不加我们就用不起来。
“解析器”也是浏览器内置的。
“DNS服务器解析”我们在网络配置中选择了“自动获得DNS服务器”,我们在这里将DNS服务器改掉,改成了美国的DNS服务器,如:8.8.8.8. 网站是无法打开,这就说明我们选择国外的DNS服务器,中文域名是无法使用的。
从上面的内容中,我们可以总结出,在目前好多浏览器在国内支持中文域名是因为cnnic和浏览器开发商之间进行了合作,让浏览器内置Punycode编码转换。所以来讲应该只有中文版的浏览器才能支持中文域名,
再从DNS服务器解析来讲,只有在国内,或者说是使用国内的DNS服务器才能支持中文域名。
附中文域名编码转换工具:http://tools.jb51.net/punycode/index.php?decoded=%E4%B8%AD%E5%A4%AE%E7%94%B5%E8%A7%86%E5%8F%B0%E7%BD%91.%E7%BD%91%E5%9D%80&encoded=&encode=%E7%BC%96%E7%A0%81
cctv央视网侵权申明:https://news.cctv.com/2020/10/23/ARTIALUGD9zJSrbdIBxuC4gE201023.shtml
RFC3490
(Request For Comments (RFC),是一系列以编号排定的文件。文件收集了有关因特网相关资讯,以及UNIX和因特网社群的软件文件。目前RFC文件是由Internet Society(ISOC)所赞助发行。)
Internationalizing Domain Names in Applications (IDNA)
用户输入国际化域名后,由应用程序完成本地码到Unicode编码的转换,然后再完成Unicode编码到7位Punycode编码的转换,然后由解析器(Resolver)发给DNS服务器进行解析。DNS服务器里存储的不是八位编码的Unicode字符串,而是经过Punycode算法处理的7位编码字符串。
IDNA中应用程序对IDN进行ToASCII和ToUnicode操作的时候会调用Punycode算法完成七位和八位数据的转换操作。
ToASCII和ToUnicode过程参见RFC3490 4.1和4.2小节
一个八位Unicode表示的域名字段的字符串将会被转化成为七位字母数字表示的字符串,并添加前缀“xn--”以便与其他英文域名区分,表示这个域名字段是IDN。
按照上面的解释,我们以侵权域名“中央电视台网.网址”为例,软件环境为ie7简体中文版
中央电视台网.网址. ==>Punycode编码转换. ===> Punycode编码转换后:
xn--fiq53l90e917a0tk4ip.xn--ses554g
www.中央电视台网.网址. =怎么编码变为下面这串的呢?=>
http://www.xn--fiq53l90e917a0tk4ip.xn--ses554g/
于是在浏览器里输入这个“中央电视台网”侵权事宜的域名:
www.中央电视台网.网址. =怎么编码变为下面这串的呢?===我们在ie7的状态栏中看到==》
http://www.xn--fiq53l90e917a0tk4ip.xn--ses554g/
在ie6的时代,是不支持中文域名的使用的,为什么现在ie7就支持了呢,我们理解一下RFC3490的内容
“由应用程序完成...”,“程序”这里是指ie7,或者更高浏览器,或者其它浏览器,“完成”指的是浏览器中内置了Punycode的转换,意思是浏览器里面主动加入了中文域名自动转码。ie7简体中文内置了自动转码工具,其它的就不知道了,说白了就是浏览器厂商将这个功能加上去,我们就能用,不加我们就用不起来。
“解析器”也是浏览器内置的。
“DNS服务器解析”我们在网络配置中选择了“自动获得DNS服务器”,我们在这里将DNS服务器改掉,改成了美国的DNS服务器,如:8.8.8.8. 网站是无法打开,这就说明我们选择国外的DNS服务器,中文域名是无法使用的。
从上面的内容中,我们可以总结出,在目前好多浏览器在国内支持中文域名是因为cnnic和浏览器开发商之间进行了合作,让浏览器内置Punycode编码转换。所以来讲应该只有中文版的浏览器才能支持中文域名,
再从DNS服务器解析来讲,只有在国内,或者说是使用国内的DNS服务器才能支持中文域名。
附中文域名编码转换工具:http://tools.jb51.net/punycode/index.php?decoded=%E4%B8%AD%E5%A4%AE%E7%94%B5%E8%A7%86%E5%8F%B0%E7%BD%91.%E7%BD%91%E5%9D%80&encoded=&encode=%E7%BC%96%E7%A0%81
cctv央视网侵权申明:https://news.cctv.com/2020/10/23/ARTIALUGD9zJSrbdIBxuC4gE201023.shtml
背景:自已写了一个简单的命令行打开网页的go程序。运行时传入参数出现:
./chrome http://gitlab.xx.xxxx.xx/irdcops/k8s.xx.xxxx.xx/-/merge_requests/new?merge_request%5Bsource_branch%5D=xiangdong
zsh: no matches found: http://gitlab.xx.xxxx.xx/irdcops/k8s.xx.xxxx.xx/-/merge_requests/new?merge_request%5Bsource_branch%5D=xiangdong
搜索了一下,找到出现的原因如下:
在 zsh 下使用 find 命令查找指定目录下所有头文件时出现问题:
find . -name *.h
1
no matches found: *.h
后来查看了一些资料才知道,这是由于zsh导致的。
具体原因:
因为zsh缺省情况下始终自己解释这个 *.h,而不会传递给 find 来解释。
解决办法:
在~/.zshrc中加入:
setopt no_nomatch, 然后进行source .zshrc命令
来自:https://blog.csdn.net/u012675539/article/details/52079013
./chrome http://gitlab.xx.xxxx.xx/irdcops/k8s.xx.xxxx.xx/-/merge_requests/new?merge_request%5Bsource_branch%5D=xiangdong
zsh: no matches found: http://gitlab.xx.xxxx.xx/irdcops/k8s.xx.xxxx.xx/-/merge_requests/new?merge_request%5Bsource_branch%5D=xiangdong
搜索了一下,找到出现的原因如下:
在 zsh 下使用 find 命令查找指定目录下所有头文件时出现问题:
find . -name *.h
1
no matches found: *.h
后来查看了一些资料才知道,这是由于zsh导致的。
具体原因:
因为zsh缺省情况下始终自己解释这个 *.h,而不会传递给 find 来解释。
解决办法:
在~/.zshrc中加入:
setopt no_nomatch, 然后进行source .zshrc命令
来自:https://blog.csdn.net/u012675539/article/details/52079013
当时方便用一下虚拟机并用暴风激活,发现注入了主页劫持病毒,出现浏览器首页被重定和到:
jn4.dhtz999.top
下载360系统急救箱V5.1.64.1255 ,http://www.360.cn/jijiuxiang/,发现驱动级木马,重启变为360的推荐主页了,不知算不算解决了?
也有人说:
360所谓的主页修复什么的,根本没用,这次是遇到真流氓了,希望及时升级吧。还有就是,火绒也是了,没用,没用。
参考来自:https://ruhetouzi.com/t/topic/101241
https://zhuanlan.zhihu.com/p/115822262
jn4.dhtz999.top
下载360系统急救箱V5.1.64.1255 ,http://www.360.cn/jijiuxiang/,发现驱动级木马,重启变为360的推荐主页了,不知算不算解决了?
也有人说:
360所谓的主页修复什么的,根本没用,这次是遇到真流氓了,希望及时升级吧。还有就是,火绒也是了,没用,没用。
参考来自:https://ruhetouzi.com/t/topic/101241
https://zhuanlan.zhihu.com/p/115822262
linux tmux/screen rz/sz 文件卡死快速退出方法
Unix/LinuxC技术 jackxiang 2020-10-12 23:49
linux tmux/screen rz/sz 文件卡死快速退出方法
按住Ctrl键, 再按五次x键 (强行终断传输)
怎么在screen下用rz/sz传输文件?
screen 可以用zmodem模式传输文件
同时按 CTRL和A键 然后输入 :zmodem pass
回车即可
tmux 未找到rz/sz传输文件办法
From:https://blog.csdn.net/qq_34104669/article/details/105231853
按住Ctrl键, 再按五次x键 (强行终断传输)
怎么在screen下用rz/sz传输文件?
screen 可以用zmodem模式传输文件
同时按 CTRL和A键 然后输入 :zmodem pass
回车即可
tmux 未找到rz/sz传输文件办法
From:https://blog.csdn.net/qq_34104669/article/details/105231853
首先,要添加一个输入法,才能删掉微软拼音输入法。否则,删除按钮是disable灰色的状态。
win10系统怎么删除默认的输入法步骤:
1、在打开的设置面板中点击点击“其他日期、时间和区域设置”,进入下一步。没有?入口2:
就到桌面的输入法处-》语言首选项-》就有一个区域和语言,新的版本是区域和语言分开的,到语言。
2、首选语言:
+添加语言
中文(简体,中国)
英文(美国)
上面这个随便点一个,会显示:[选项] [删除],点选项。
有一个中文(中华人民共和国)显示语言:在上面点鼠标左键,才会显示出选项,我就是一直没找到这个,原来在这儿要点一下,这个细节要注意。
3、进去语言选项:中文(简体,中国),键盘:就是设置了里面的键盘,就有添加键盘,同2一样点微软自己的输入法后,会显示删除两字(如果只有一个微软输入法删除按钮变灰),再新加一个输入法后,再回到微软拼音上点一下,其下面[选项][删除]就能删掉自带的微软输入法了。
参考:https://blog.csdn.net/qq_40907977/article/details/107866250
win10系统怎么删除默认的输入法步骤:
1、在打开的设置面板中点击点击“其他日期、时间和区域设置”,进入下一步。没有?入口2:
就到桌面的输入法处-》语言首选项-》就有一个区域和语言,新的版本是区域和语言分开的,到语言。
2、首选语言:
+添加语言
中文(简体,中国)
英文(美国)
上面这个随便点一个,会显示:[选项] [删除],点选项。
有一个中文(中华人民共和国)显示语言:在上面点鼠标左键,才会显示出选项,我就是一直没找到这个,原来在这儿要点一下,这个细节要注意。
3、进去语言选项:中文(简体,中国),键盘:就是设置了里面的键盘,就有添加键盘,同2一样点微软自己的输入法后,会显示删除两字(如果只有一个微软输入法删除按钮变灰),再新加一个输入法后,再回到微软拼音上点一下,其下面[选项][删除]就能删掉自带的微软输入法了。
参考:https://blog.csdn.net/qq_40907977/article/details/107866250
[实践OK]easyswoole验证器,如何在控制器使用验证例子(demo)
Php/Js/Shell/Go jackxiang 2020-10-8 22:51
验证器:
https://www.bookstack.cn/read/easyswoole-3.x-zh/Components-validate.md
App/HttpController/Index.php
App/HttpController/BaseController.php
统一验证:
class Index extends BaseController
{
function index()
{
$this->response()->write("123");
}
/**
* 验证
*
* {@inheritdoc}
* @see \App\HttpController\Index\Index::validateRule()
*/
protected function validateRule(?string $action): ?Validate
{
$v = new Validate();
$params = $this->request()->getRequestParam();
echo "Here:\n";
var_dump($action);
switch ($action) {
case 'index':
{
$v->addColumn('title', '竞赛标题')
->required('不能为空')
->notEmpty();
$v->addColumn('limit', '每页条数')
->integer();
$v->addColumn('page', '当前页码')
->integer();
if (isset($params['recommend_status'])) {
$v->addColumn('recommend_status', '推荐状态')->integer();
}
if (isset($params['act_status'])) {
$v->addColumn('act_status', '活动状态')->integer();
}
break;
}
case 'searchActivity':
{
$v->addColumn('title', '竞赛标题')
->required('不能为空')
->notEmpty();
$v->addColumn('limit', '每页条数')
->integer();
$v->addColumn('page', '当前页码')
->integer();
if (isset($params['recommend_status'])) {
$v->addColumn('recommend_status', '推荐状态')->integer();
}
if (isset($params['act_status'])) {
$v->addColumn('act_status', '活动状态')->integer();
}
break;
}
case 'getRobotAnswer':
{
$v->addColumn('topic_id', '题目id')
->required('不能为空')
->integer();
$v->addColumn('score', '积分')
->integer();
break;
}
case 'saveActivity':
{
$v->addColumn('title', '竞赛标题')
->required('不能为空')
->notEmpty();
$v->addColumn('type', '展示模式')
->required('不能为空')
->integer();
$v->addColumn('description', '竞赛描述')
->required('不能为空')
->notEmpty();
$v->addColumn('start_time', '开始时间')
->required('不能为空')
->integer();
$v->addColumn('end_time', '结束时间')
->required('不能为空')
->integer();
$v->addColumn('paper_status', '试卷状态')
->required('不能为空')
->integer();
$v->addColumn('act_status', '活动状态')
->required('不能为空')
->integer();
if (isset($params['act_id'])) {
$v->addColumn('act_id', '竞赛id')->integer();
}
if (isset($params['recommend_status'])) {
$v->addColumn('recommend_status', '推荐状态')->integer();
}
if (isset($params['recommend_index'])) {
$v->addColumn('recommend_index', '推荐序号')->integer();
}
break;
}
case 'delActivity':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer()
->min(0);
break;
}
case 'getActivity':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
break;
}
case 'getActivityList':
{
$v->addColumn('recommend_status', '推荐状态')
->required('不能为空')
->integer();
$v->addColumn('limit', '列表数')
->required('不能为空')
->integer();
break;
}
case 'getPaper':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('paper_nums', '试卷题量')
->required('不能为空')
->integer();
break;
}
case 'addPaperTopic':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('topic_id', '题目id')
->required('不能为空')
->notEmpty();
$v->addColumn('topic_title', '题目标题')
->required('不能为空')
->notEmpty();
$v->addColumn('topic_label', '题目标签')
->required('不能为空')
->notEmpty();
break;
}
case 'delPaperTopic':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('topic_id', '题目id')
->required('不能为空')
->notEmpty();
break;
}
case 'updatePaper':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('type', '答题类型')
->required('不能为空')
->integer();
$v->addColumn('nums', '题量')
->required('不能为空')
->integer();
break;
}
case 'updateScoreSet':
{
$v->addColumn('per_score', '答对得分')
->required('不能为空')
->integer();
$v->addColumn('win_score', '获胜得分')
->required('不能为空')
->integer();
$v->addColumn('fail_score', '失败得分')
->required('不能为空')
->integer();
break;
}
}
return $v;
}
App/HttpController/BaseController.php
https://www.bookstack.cn/read/easyswoole-3.x-zh/Components-validate.md
App/HttpController/Index.php
App/HttpController/BaseController.php
统一验证:
class Index extends BaseController
{
function index()
{
$this->response()->write("123");
}
/**
* 验证
*
* {@inheritdoc}
* @see \App\HttpController\Index\Index::validateRule()
*/
protected function validateRule(?string $action): ?Validate
{
$v = new Validate();
$params = $this->request()->getRequestParam();
echo "Here:\n";
var_dump($action);
switch ($action) {
case 'index':
{
$v->addColumn('title', '竞赛标题')
->required('不能为空')
->notEmpty();
$v->addColumn('limit', '每页条数')
->integer();
$v->addColumn('page', '当前页码')
->integer();
if (isset($params['recommend_status'])) {
$v->addColumn('recommend_status', '推荐状态')->integer();
}
if (isset($params['act_status'])) {
$v->addColumn('act_status', '活动状态')->integer();
}
break;
}
case 'searchActivity':
{
$v->addColumn('title', '竞赛标题')
->required('不能为空')
->notEmpty();
$v->addColumn('limit', '每页条数')
->integer();
$v->addColumn('page', '当前页码')
->integer();
if (isset($params['recommend_status'])) {
$v->addColumn('recommend_status', '推荐状态')->integer();
}
if (isset($params['act_status'])) {
$v->addColumn('act_status', '活动状态')->integer();
}
break;
}
case 'getRobotAnswer':
{
$v->addColumn('topic_id', '题目id')
->required('不能为空')
->integer();
$v->addColumn('score', '积分')
->integer();
break;
}
case 'saveActivity':
{
$v->addColumn('title', '竞赛标题')
->required('不能为空')
->notEmpty();
$v->addColumn('type', '展示模式')
->required('不能为空')
->integer();
$v->addColumn('description', '竞赛描述')
->required('不能为空')
->notEmpty();
$v->addColumn('start_time', '开始时间')
->required('不能为空')
->integer();
$v->addColumn('end_time', '结束时间')
->required('不能为空')
->integer();
$v->addColumn('paper_status', '试卷状态')
->required('不能为空')
->integer();
$v->addColumn('act_status', '活动状态')
->required('不能为空')
->integer();
if (isset($params['act_id'])) {
$v->addColumn('act_id', '竞赛id')->integer();
}
if (isset($params['recommend_status'])) {
$v->addColumn('recommend_status', '推荐状态')->integer();
}
if (isset($params['recommend_index'])) {
$v->addColumn('recommend_index', '推荐序号')->integer();
}
break;
}
case 'delActivity':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer()
->min(0);
break;
}
case 'getActivity':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
break;
}
case 'getActivityList':
{
$v->addColumn('recommend_status', '推荐状态')
->required('不能为空')
->integer();
$v->addColumn('limit', '列表数')
->required('不能为空')
->integer();
break;
}
case 'getPaper':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('paper_nums', '试卷题量')
->required('不能为空')
->integer();
break;
}
case 'addPaperTopic':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('topic_id', '题目id')
->required('不能为空')
->notEmpty();
$v->addColumn('topic_title', '题目标题')
->required('不能为空')
->notEmpty();
$v->addColumn('topic_label', '题目标签')
->required('不能为空')
->notEmpty();
break;
}
case 'delPaperTopic':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('topic_id', '题目id')
->required('不能为空')
->notEmpty();
break;
}
case 'updatePaper':
{
$v->addColumn('act_id', '竞赛id')
->required('不能为空')
->integer();
$v->addColumn('type', '答题类型')
->required('不能为空')
->integer();
$v->addColumn('nums', '题量')
->required('不能为空')
->integer();
break;
}
case 'updateScoreSet':
{
$v->addColumn('per_score', '答对得分')
->required('不能为空')
->integer();
$v->addColumn('win_score', '获胜得分')
->required('不能为空')
->integer();
$v->addColumn('fail_score', '失败得分')
->required('不能为空')
->integer();
break;
}
}
return $v;
}
App/HttpController/BaseController.php
管道菜单“/usr/bin/obamenu”的输出无效
Unix/LinuxC技术 jackxiang 2020-9-29 15:06
Linux shell 获取目录下时间最新的文件的文件名
Unix/LinuxC技术 jackxiang 2020-9-28 17:27
ls -lt /dirname/ | grep filename | head -n 1 |awk '{print $9}'
逐条解释:
ls -lt /dirname/
列出此目录下的所有文件并按照时间先后排序
grep filename
过滤出包含关键字的文件
head -n 1
查看排名第一的文件
awk '{print $9}'
打印出第九字段,此处为文件名
来自:https://www.cnblogs.com/echo-valley/p/8268527.html