Jupyter Notebook安装于虚拟机或云服务器

系统为Ubuntu Server 22.04.2。

pip install jupyter
jupyter notebook --generate-config
vim ~/.jupyter/jupyter_notebook_config.py

在ipython,用jupyter自带的密码生成器生成哈希密码,复制最终的out结果

ipython
>>> from notebook.auth import passwd
>>> passwd()

修改配置文件中的配置(必须要修改ip才能在外网访问)

c.NotebookApp.ip = 'xxx.xxx.xx.xx'
c.NotebookApp.open_browser = False
c.NotebookApp.password = ''  #此处应为前文中复制的哈希密码
c.NotebookApp.port = 8888
c.NotebookApp.allow_remote_access = True

防火墙开放8888端口

sudo ufw allow 8888

启动Jupyter Notebook

jupyter notebook

外网访问IP:8888即可

(notebook中的python环境可能与系统的环境不一致,进而出现找不到依赖库的情况,最简单的方法是直接在notebook中安装包,从根源上解决就得给notebook配置kernel)

! pip install numpy    #在jupyter notebook 中直接安装库

Swoole的安装(包括yasd调试)

在Ubuntu系统下,安装需要的包:

sudo apt install php gcc make autoconf php-dev

下载源代码

解压,并安装:

sudo tar -xzvf swoole-src-5.0.0.tar.gz
cd cd swoole-src-5.0.0/
sudo phpize
sudo ./configure
sudo make -j6
sudo make install

还需在php.ini中添加:

extension=swoole.so

编译安装yasd

sudo apt install libboost-all-dev
git clone https://github.com/swoole/yasd.git
cd yasd/
sudo phpize --clean
sudo phpize
sudo ./configure
sudo make clean
sudo make
make install

在php.ini中添加:

zend_extension=yasd
yasd.debug_mode=remote
yasd.remote_host=127.0.0.1
yasd.remote_port=9000

如果采用phpstorm的ssh模式使用解释器,还需要设置部署及路径映射。

基于WVP-GB28181的云视频监控管理平台配置

wvp的GitHub页面648540858/wvp-GB28181-pro

wvp-Docker的GitHub页面 imnicn/wvp-docker

采用Ubuntu20.04的腾讯云服务器,配置最新版本Docker及docker-compose。

wget -qO- https://get.docker.com/ | sh
systemctl enable docker
systemctl start docker
apt install docker-compose

首先克隆wvp-docker的代码:

git clone https://github.com/imnicn/wvp-docker.git

接着进入wvp-docker目录,修改docker-compose配置文件,包括wvp和zml的IP,以及相关的SIP编号、密码等。(编号规则见GB附录)

保存配置文件后,启动docker-compose即可

docker-compose up -d

初次启动时存在无法连接到媒体服务器的Bug,需要docker-compose down后重新up才能正常。

大华的28181配置修改后可能存在延迟,需要重启机器。

由于国标采用了推模式,摄像头、NVR等设备不需要公网IP,也(可能)不需要端口映射。

Ubuntu 20修改网络配置

原有的/etc/network/interfaces方法已经不适用,现需要:

sudo vi /etc/netplan/00-installer-config.yaml

yaml格式的样本:

# This is the network config written by 'subiquity'
network:
  ethernets:
    ens160:
      dhcp4: false
      addresses: [192.168.3.18/24]
      gateway4: 192.168.1.1
      nameservers:
        addresses: [223.5.5.5,119.29.29.29]

  version: 2

修改完成后,应用配置:

sudo netplan apply

Debian部署MiniKube

检查Debian发行版版本:

cat /etc/os-release

更新(建议使用VPN):

sudo apt update
sudo apt upgrade

安装Docker

//移除潜在的老版本Docker
sudo apt-get remove docker docker-engine docker.io containerd runc
//安装需要的包
sudo apt-get install ca-certificates curl gnupg lsb-release
//添加Docker官方的GPG密钥(需关闭V2Ray,否则SSL报错)
curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
//添加稳定版仓库
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/debian \
  $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
//安装Docker(需关闭V2Ray,否则SSL报错)
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io
//检查是否安装成功
docker -v

安装MiniKube

curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube_latest_amd64.deb
sudo dpkg -i minikube_latest_amd64.deb

启动MiniKube(需拉取镜像,建议使用VPN):

minikube start
//可能报错未添加Docker组,则需要添加用户组:
sudo usermod -aG docker $USER && newgrp docker

TrueNAS移除条带池(strip)中硬盘的方法

因意外,将要作为cache/log的傲腾硬盘当作tank加入到了strip池中,在Web管理页面无法将其移除。

使用ssh或web命令行可移除。

zpool list -v cache
//查看目前cache池的状态

根据池中硬盘的ID,移除硬盘:

zpool remove cache gptid/7b5dddfa-b754-11eb-a683-000c29a6c389

移除过程需要一段时间,之后在list -v就没有这个硬盘了。

PS:官方不推荐使用remove指令,有降低池性能的可能,仅适合应急使用。如果池中文件较少或有条件转移,建议rebuild整个池。

TrueNAS(FreeBSD)通过Jail安装calibre-web

首先在TrueNAS的Web管理界面新建Jail。

新建Jail

配置网络,建议关闭IPv4的DHCP,以便于管理。

网络配置

待Jail配置完成后,启动Jail并进入命令行。

进入命令行

在命令行中,以此执行以下指令:

pkg update
//若提示需要安装pkg,输入y,可能等待较长时间。
pkg install sqlite3 libxml2 libxslt python3
//安装需要的依赖包
python3 -V
//查询python3具体版本,便于安装扩展包,本次安装的版本为Python3.8
pkg install py38-sqlite3 py38-pip
//安装对应的sqlite3、pip扩展包
pip install calibreweb
//使用pip安装calibreweb
cps
//运行calibreweb,正常情况下没有任何输出,且关闭命令行将终止运行
nohup cps
//使用nohup指令保持calibreweb在后台运行,但关闭终端后,若安装豆瓣搜刮插件,元数据搜索将出现错误。
//推荐使用screen命令,具体在此不对赘述。

calibreweb默认使用8083端口提供Web服务,即在浏览器中打开http://address:8083即可进行配置,默认用户名为admin,默认密码为admin123。

首次登陆

登陆后可能会要求Database,稍后再说。

可以将存有图书的目录作为挂载点挂在到Jail上(挂在是需终止Jail)。

添加挂载点
添加挂载点
添加挂载点
添加挂载点

在Windows上安装calibre软件,并新建一个书库,在书库文件夹中找到metadata.db文件,或点击下载,并上传到True NAS的挂载目录里。重新启动Jail并运行calibreweb后,设置database location为上传的文件即可(记得修改文件权限)。

元数据中,豆瓣搜刮的插件使用github上的开源代码点击打开,按照说明添加文件后重启即可。

电子书格式转换功能直接使用Windows的文件不成功,需要在Jail里安装calibre:

pkg install calibre

安装好后,在calibre-web的设置→编辑基本设置→扩展程序配置中,设置Calibre 电子书转换器路径,默认路径为:

/usr/local/bin/ebook-convert

PS:默认上传功能未开启,且admin上传权限也需要手动允许。

PHP中时间的处理

常用格式符号:

d - 表示月里的某天(01-31)
m - 表示月(01-12)
Y - 表示年(四位数)
1 - 表示周里的某天
h - 带有首位零的 12 小时小时格式
i - 带有首位零的分钟
s - 带有首位零的秒(00 -59)
a - 小写的午前和午后(am 或 pm)

无需转换可使用date()函数:

date('Y-m-d h:i:sa');
date('Y-m-d h:i:sa', $d);  //$d为Unix时间戳

可使用mktime()函数获得某一日期的Unix时间戳:

mktime(hour,minute,second,month,day,year)

strtotime()函数可将自然语言智能的转化为时间戳(个人认为不可靠):

strtotime("10:38pm April 15 2015");
strtotime("tomorrow");
strtotime("next Saturday");
strtotime("+3 Months");
strtotime("+6 weeks",$startdate);

可也是用DateTime类进行高级操作:

$datetime = new \DateTime;
$datetime->format('Y-m-d H:i:s');

$datetime = new \DateTime('2016-06-13');

$datetime = \DateTime::createFromFormat('Ymd','20160618');
 
$datetime->getTimestamp();

$datetime->setTimestamp();

$datetime->setDate(2015, 2, 28); //类似mktime()


$datetime1 = new \DateTime('2016-01-01 10:11:18');
 
$datetime2 = new \DateTime('2017-05-11 22:21:21');
 
$interval = $datetime1->diff($datetime2);
 
print_r($interval->format('%Y'));
 
// %表示使用格式化,R表示是大于这个日期(+),还是小于这个日期(-),a表示大于或小于多少天,时分秒正常使用y,m,d,h,i,s

WordPress插件开发笔记

1、add_menu_page采用与add_submenu_page相同的callback function可去除与menu重复的submenu。

2、使用 $wpdb->prepare可使用%而不冲突。

$wpdb->query(‘query’); //直接的Query语句

$wpdb->get_var(‘query’,column_offset,row_offset); //得到一个变量值

$wpdb->get_row(‘query’, output_type,row_offset); //得到一行的数组

$wpdb->get_col(‘query’,column_offset); //得到一列的数组

$wpdb->get_results(‘query’, output_type); //一个对象数组

$wpdb->insert( $table, $data, $format );

$wpdb->update( $table, $data, $where, $format = null, $where_format = null );

$wpdb->prepare( ‘query’ [, value_parameter, value_parameter … ] );

$wpdb->show_errors();

$wpdb->hide_errors();

$wpdb->print_error();

$wpdb->get_col_info(‘type’, offset);

$wpdb->flush();

3、修改JS的时候,要在Edge(或Chrome)的控制台中的网络里禁止缓存。

4、从后端传回的JSON数据是string,需要转换才能变成数组。

response=JSON.parse(response);

5、JS中长的HTML字符串可以用`约束。

6、PHP的性能优化。引用

1、如果能将类的方法定义成static,就尽量定义成static,它的速度会提升将近4倍。
2、$row[’id’] 的速度是$row[id]的7倍。
3、注销那些不用的变量尤其是大数组,以便释放内存。
4、尽量避免使用__get,__set,__autoload。
5、require_once()代价昂贵。
6、include文件时尽量使用绝对路径,因为它避免了PHP去include_path里查找文件的速度,解析操作系统路径所需的时间会更少。
7、如果你想知道脚本开始执行(译注:即服务器端收到客户端请求)的时刻,使用$_SERVER[‘REQUEST_TIME’]要好于time()
8、函数代替正则表达式完成相同功能。
9、str_replace函数比preg_replace函数快,但strtr函数的效率是str_replace函数的四倍。
10、如果一个字符串替换函数,可接受数组或字符作为参数,并且参数长度不太长,那么可以考虑额外写一段替换代码,使得每次传递参数是一个字符,而不是只写一行代码接受数组作为查询和替换的参数。
11、使用选择分支语句(译注:即switch case)好于使用多个if,else if语句。
12、用@屏蔽错误消息的做法非常低效,极其低效。
13、打开apache的mod_deflate模块,可以提高网页的浏览速度。
14、数据库连接当使用完毕时应关掉,不要用长连接。
15、在方法中递增局部变量,速度是最快的。几乎与在函数中调用局部变量的速度相当。递增一个全局变量要比递增一个局部变量慢2倍。递增一个对象属性(如:$this->prop++)要比递增一个局部变量慢3倍。递增一个未预定义的局部变量要比递增一个预定义的局部变量慢9至10倍。
16、仅定义一个局部变量而没在函数中调用它,同样会减慢速度(其程度相当于递增一个局部变量)。PHP大概会检查看是否存在全局变量。
17、方法调用看来与类中定义的方法的数量无关,因为我(在测试方法之前和之后都)添加了10个方法,但性能上没有变化。
18、派生类中的方法运行起来要快于在基类中定义的同样的方法。
19、调用带有一个参数的空函数,其花费的时间相当于执行7至8次的局部变量递增操作。类似的方法调用所花费的时间接近于15次的局部变量递增操作。
20、Apache解析一个PHP脚本的时间要比解析一个静态HTML页面慢2至10倍。尽量多用静态HTML页面,少用脚本。
21、除非脚本可以缓存,否则每次调用时都会重新编译一次。引入一套PHP缓存机制通常可以提升25%至100%的性能,以免除编译开销。
22、尽量做缓存,可使用memcached。memcached是一款高性能的内存对象缓存系统,可用来加速动态Web应用程序,减轻数据库负载。对运算码 (OP code)的缓存很有用,使得脚本不必为每个请求做重新编译。
23、当操作字符串并需要检验其长度是否满足某种要求时,你想当然地会使用strlen()函数。此函数执行起来相当快,因为它不做任何计算,只返回在zval 结构(C的内置数据结构,用于存储PHP变量)中存储的已知字符串长度。但是,由于strlen()是函数,多多少少会有些慢,因为函数调用会经过诸多步骤,如字母小写化(译注:指函数名小写化,PHP不区分函数名大小写)、哈希查找,会跟随被调用的函数一起执行。在某些情况下,你可以使用isset() 技巧加速执行你的代码。
24、当执行变量$i的递增或递减时,$i++会比++$i慢一些。这种差异是PHP特有的,并不适用于其他语言,所以请不要修改你的C或Java代码并指望它们能立即变快,没用的。++$i更快是因为它只需要3条指令(opcodes),$i++则需要4条指令。后置递增实际上会产生一个临时变量,这个临时变量随后被递增。而前置递增直接在原值上递增。这是最优化处理的一种,正如Zend的PHP优化器所作的那样。牢记这个优化处理不失为一个好主意,因为并不是所有的指令优化器都会做同样的优化处理,并且存在大量没有装配指令优化器的互联网服务提供商(ISPs)和服务器。
25、并不是事必面向对象(OOP),面向对象往往开销很大,每个方法和对象调用都会消耗很多内存。
26、并非要用类实现所有的数据结构,数组也很有用。
27、尽量采用大量的PHP内置函数。
28、如果在代码中存在大量耗时的函数,你可以考虑用C扩展的方式实现它们。
29、评估检验(profile)你的代码。检验器会告诉你,代码的哪些部分消耗了多少时间。Xdebug调试器包含了检验程序,评估检验总体上可以显示出代码的瓶颈。
30、mod_zip可作为Apache模块,用来即时压缩你的数据,并可让数据传输量降低80%。
31、在可以用file_get_contents替代file、fopen、feof、fgets等系列方法的情况下,尽量用file_get_contents,因为他的效率高得多!但是要注意file_get_contents在打开一个URL文件时候的PHP版本问题;
32、尽量的少进行文件操作,虽然PHP的文件操作效率也不低的;
33、优化Select SQL语句,在可能的情况下尽量少的进行Insert、Update操作(在update上,我被恶批过);
34、循环内部不要声明变量,尤其是大变量:对象(这好像不只是PHP里面要注意的问题吧?);
35、多维数组尽量不要循环嵌套赋值;
36、在可以用PHP内部字符串操作函数的情况下,不要用正则表达式;
37、foreach效率更高,尽量用foreach代替while和for循环;
38、用单引号替代双引号引用字符串;
39、“用i+=1代替i=i+1。符合c/c++的习惯,效率还高”;
40、对global变量,应该用完就unset()掉;

华为笔记本配置电阻探究

PS:终止。荣耀MagicBook(KPL-W00)的官方BIOS中没有16G的SPD信息。淘宝的扩展服务还不如把电脑埋了换个Y9000X。

PS*:重启,发现之所以4G是因为双通道,两条DIMM合成8G,两条8G的SPD合成16G。

PS**:再次终止,原厂BIOS中SPD的8G非常奇怪,疑似单通道8G的78球FBGA的SPD(有校验,不能随便改,只能替换),且需要增加group线(原厂未连通),风险太大。

配置电阻

HMA851S6AFR6N-UH 对应 Hynix 8G 2400

//HMA851S6CJR6N-VK 对应 Hynix 8G 2666

//HMAA1GS6CMR6N-VK 对应 Hynix 16G 2666

//M471A5244CB0-CTD 对应 Samsung 8G 1R16 2666

M471A5244BB0-CRC 对应 Samsung 8G 1R16 2400

MTA4ATF51264HZ-2G3B 对应Micron 4G 2400

M471A1K43BB1-CRC 对应 Samsung 8G 2400

计划使用
K4AAG165WB-MCRC
H5ANAG6NCMR-VKC

利用IDA Freeware反编译官方的BIOS,寻找APCB开头的SPD信息,内有包含各种内存条的名称的string(不是颗粒名称)。

美光颗粒命名规则

百度贴吧-荣耀升级案例

百度贴吧-XPS升级案例

WPSuperCache的Nginx配置

使用WPSuperCache必须令WordPress使用固定链接,而WordPress的固定链接在Nginx条件下必须修改nginx.conf(否则页面404),添加如下代码:

location / {
try_files $uri $uri/ /index.php?$args;
}

(而在Apache中则是一个名为rename的功能)。