首页
关于
留言
Search
1
红米 AX3000 (AX6) 路由器解锁 SSH 教程
6,676 阅读
2
网盘挂载程序sharelist美化教程
4,216 阅读
3
小米路由器 AX3600 开启SSH教程,官方固件即可安装 ShellClash开启科学上网
2,168 阅读
4
Oracle 甲骨文 ARM VPS 自动抢购脚本
1,819 阅读
5
编译带PassWall和SSR-plus插件的Openwrt系统
1,393 阅读
前端
Vue
React
后端
Java
Python
PHP
数据库
运维
杂谈
小程序
影视资源
登录
Search
标签搜索
Java
Linux
Mysql
IDEA
Debian
Docker
Springboot
CentOS
Cloudflare
Maven
JavaScript
SQL
Wordpress
宝塔
Nginx
Windows
MacBook
JS
CSS
Openwrt
William
累计撰写
144
篇文章
累计收到
702
条评论
首页
栏目
前端
Vue
React
后端
Java
Python
PHP
数据库
运维
杂谈
小程序
影视资源
页面
关于
留言
搜索到
144
篇与
的结果
2022-04-03
nohup 和 & 后台运行,进程查看及终止
nohup用途:不挂断地运行命令。语法:nohup Command [ Arg … ] [ & ]无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。退出状态:该命令返回下列出口值:126 可以查找但不能调用 Command 参数指定的命令。127 nohup 命令发生错误或不能查找由 Command 参数指定的命令。否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。&用途:在后台运行一般两个一起用 nohup command &例子:nohup /usr/local/node/bin/node /www/im/chat.js >> /usr/local/node/output.log 2>&1 &查看运行的后台进程jobs -ljobs 命令只看当前终端生效的,关闭终端后,在另一个终端 jobs 已经无法看到后台跑得程序了,此时利用 ps(进程查看命令)ps -efps -aux|grep chat.jsa:显示所有程序 u:以用户为主的格式来显示 x:显示所有程序,不以终端机来区分注:用 ps -def | grep 查找进程很方便,最后一行总是会 grep 自己用 grep -v 参数可以将 grep 命令排除掉ps -aux | grep xxx | grep -v grepaux 输出格式USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMANDUSER: 行程拥有者PID: pid%CPU: 占用的 CPU 使用率%MEM: 占用的记忆体使用率VSZ: 占用的虚拟记忆体大小RSS: 占用的记忆体大小TTY: 终端的次要装置号码 (minor device number of tty)STAT: 该行程的状态:D: 无法中断的休眠状态 (通常 IO 的进程)R: 正在执行中S: 静止状态T: 暂停执行Z: 不存在但暂时无法消除W: 没有足够的记忆体分页可分配<: 高优先序的行程N: 低优先序的行程L: 有记忆体分页分配并锁在记忆体内 (实时系统或捱A I/O)START: 行程开始时间TIME: 执行的时间COMMAND:所执行的指令再用 awk 提取一下 进程IDps -aux | grep chat.js | grep -v grep | awk '{print $2}'后台日志输出到文件关于如何将后台日志输出到文件,可看本博客前面发的文章:Linux定时任务crontab将错误日志与正确输出写入到文件如果某个进程起不来,可能是某个端口被占用查看使用某端口的进程lsof -i:8090netstat -ap|grep 8090查看到进程 id 之后,使用 netstat 命令查看其占用的端口netstat -nap|grep 7779终止后台运行的进程kill -9 进程号
2022年04月03日
31 阅读
0 评论
0 点赞
2022-03-31
在 Linux 上如何清除内存的 Cache、Buffer 和交换空间
像任何其他的操作系统一样,GNU/Linux 已经实现的内存管理不仅有效,而且更好。但是,如果有任何进程正在蚕食你的内存,而你想要清除它的话,Linux 提供了一个刷新或清除RAM缓存方法。如何在 Linux 中清除缓存(Cache)?每个 Linux 系统有三种选项来清除缓存而不需要中断任何进程或服务。(LCTT 译注:Cache,译作“缓存”,指 CPU 和内存之间高速缓存。Buffer,译作“缓冲区”,指在写入磁盘前的存储再内存中的内容。在本文中,Buffer 和 Cache 有时候会通指。)仅清除页面缓存(PageCache)sync; echo 1 > /proc/sys/vm/drop_caches清除目录项和inodesync; echo 2 > /proc/sys/vm/drop_caches清除页面缓存,目录项和inodesync; echo 3 > /proc/sys/vm/drop_caches上述命令的说明:sync 将刷新文件系统缓冲区(buffer),命令通过“;”分隔,顺序执行,shell在执行序列中的下一个命令之前会等待命令的终止。正如内核文档中提到的,写入到 drop_cache 将清空缓存而不会杀死任何应用程序/服务,echo 命令做写入文件的工作。如果你必须清除磁盘高速缓存,第一个命令在企业和生产环境中是最安全,echo 1 >只会清除页面缓存。 在生产环境中不建议使用上面的第三个选项 echo 3 >,除非你明确自己在做什么,因为它会清除 缓存页,目录项 和 inodes。在 Linux 上释放也许被内核所使用的缓冲区(Buffer)和缓存(Cache)是否是个好主意?当你设置许多设定想要检查效果时,如果它实际上是专门针对 I/O 范围的基准测试,那么你可能需要清除缓冲区和缓存。你可以如上所示删除缓存,无需重新启动系统(即无需停机)。Linux 被设计成它在寻找磁盘之前到磁盘缓存寻找的方式。如果它发现该资源在缓存中,则该请求不会发送到磁盘。如果我们清理缓存,磁盘缓存就起不到作用了,系统会到磁盘上寻找资源。此外,当清除缓存后它也将减慢系统运行速度,系统会将每一个被请求的资源再次加载到磁盘缓存中。现在,我们将创建一个 shell 脚本,通过一个 cron 调度任务在每天下午2点自动清除RAM缓存。如下创建一个 shell 脚本 clearcache.sh 并在其中添加以下行:注意,我们这里使用了 "echo 3",但是不推荐使用在产品环境中,应该使用 "echo 1"#!/bin/bash echo "echo 3 > /proc/sys/vm/drop_caches"给 clearcache.sh 文件设置执行权限chmod 755 clearcache.sh现在,当你需要清除内存缓存时只需要调用脚本。现在设置一个每天下午2点的定时任务来清除RAM缓存,打开 crontab 进行编辑。crontab -e添加以下行,保存并退出。0 3 * * * /path/to/clearcache.sh在生产环境的服务器上自动清除RAM是否是一个好主意?不!它不是。想想一个情况,当你已经预定脚本在每天下午2点来清除内存缓存。那么其实该脚本会执行并刷新你的内存缓存。在某一天由于某些原因,可能您的网站的在线用户会超过预期地从你的服务器请求资源。而在这时,按计划调度的脚本运行了,并清除了缓存中的一切。当所有的用户都从磁盘读取数据时,这将导致服务器崩溃并损坏数据库。因此,清除缓存仅在必要时并且在你的预料之中,否则你就是个呆瓜系统管理员。如何清除 Linux 的交换空间?如果你想清除掉 swap(交换空间),你可以运行下面的命令:swapoff -a && swapon -a此外,了解有关风险后,您可以将上面的命令添加到 cron 中。现在,我们将上面两种命令结合成一个命令,写成正确的脚本来同时清除RAM缓存和交换空间。echo 3 > /proc/sys/vm/drop_caches && swapoff -a && swapon -a && printf '\n%s\n' 'Ram-cache and Swap Cleared'或su -c 'echo 3 > /proc/sys/vm/drop_caches' && swapoff -a && swapon -a && printf '\n%s\n' 'Ram-cache and Swap Cleared'
2022年03月31日
32 阅读
0 评论
0 点赞
2022-03-31
Oracle 甲骨文 ARM VPS 自动抢购脚本
oci请求几乎无延迟(为了保险起见加了5s的间隔,会自动判断请求返回值动态调整请求时间)自动获取开机的 公网IP,无需登陆后台即可ssh登陆机器安装ocibash -c "$(curl –L https://raw.githubusercontent.com/oracle/oci-cli/master/scripts/install/install.sh)"一路会车 然后执行 exec -l $SHELL 重启 shell使用 oci -v 命令可以查看是否安装成功,返回版本号就是成功了。获取租户和用户的ocid甲骨文后台右上角 >> 用户设置 >> 分别点击用户和租户,在信息栏中有我们需要的ID,分别点击复制,可以保存在记事本备份好。具体看图: 配置cli输入如下代码开始配置,配置的路径默认在 root 目录。oci setup config然后输入你的 用户ocid , 租户ocid , 选择区域 ,剩下的都是回车默认然后复制生成的公钥,获取命令如下:cat /root/.oci/oci_api_key_public.pem把展示出来的内容复制下来。并且添加到,甲骨文后台 >> 用户设置 >> 资源 >> API秘钥 >> 添加API秘钥,把上一步复制的公钥粘贴进去保存。检查oci配置oci iam availability-domain list如果类似下面这样的 JSON 返回,表示配置正确,如果不是,检查你前面的配置:{ "data": [ { "compartment-id": "ocid1.tenancy.oc1..aaaaaaaauoxxxxxxxxxxxxx", "id": "ocid1.availabilitydomain.oc1..aaaaaaaaaixxxxxxxxxxxxx", "name": "uffff:AP-TOKYO-1-AD-1" } ] }获取脚本并安装依赖git clone https://github.com/cimmu/oracle-arm cd oracle-arm pip3 install -r requirements.txt隐藏内容,请前往内页查看详情喜报首尔区域ARM经历68063次尝试后成功开启
2022年03月31日
1,819 阅读
202 评论
1 点赞
2022-03-29
用 acme.sh 免费为网站域名申请 SSL 证书开启 Https 并自动续期
为什么要给网站开启 Https,做网站的应该都知道吧,哪怕不是站长应该有略有所闻,没有 https 证书的网站,浏览器打开时会提示不安全,很多时候大家看到提示不安全都会关闭,这对网站来说是一件非常糟糕的事情,另外对于需要用到支付功能的网站,没有 https 更加不安全。如果你想搞微信小程序,没有不仅要开启 https,TLS 最低还得是 1.2版本。安装 acme.shcurl https://get.acme.sh | sh脚本会自动为你创建 cronjob, 每天 0:00 点自动检测所有的证书, 如果快过期了, 需要更新, 则会自动更新证书安装以后默认会给 acme.sh 生成别名,如果执行 acme.sh 报错 not found。需执行source ~/.bashrc手动 alias 命令 (没有alias的可手动添加):alias acme.sh=~/.acme.sh/acme.sh另外,acme.sh 已经被 ZeroSSL 商业收购, acme.sh 更改默认申请证书的服务商为 ZeroSSL。商业公司的数据可能说卖就卖了所以最好更改一下默认 CA 颁发机构,更改默认证书颁发机构为 letsencryptacme.sh --set-default-ca --server letsencrypt如果服务器还没有运行任何 web 服务, 80 端口是空闲的是,那就使用 standalone 模式,还需要另外安装 socatDebian / Ubuntuapt update -y && apt install -y socatCentOSyum update -y && yum update -y && yum install -y socat申请证书及密钥如果不替换默认CA,使用 zerossl 的话,需要先注册acme.sh --register-account -m xxxx@gmail.com申请 Let's Encrypt 的直接从下面开始执行acme.sh --issue -d 你的域名 --standalone如果前面没有更换默认CA,也可以在申请时指定acme.sh --issue -d 你的域名 --server letsencrypt --standalone 下载证书及密钥下载后,在 root 根目录下,会有一个 cert.crt 和 private.key 文件acme.sh --install-cert -d 你的域名 --key-file /root/private.key --fullchain-file /root/cert.crt撤销证书,使用:acme.sh --list acme.sh --revoke -d mydomain.com删除证书,使用:acme.sh --list acme.sh --remove -d mydomain.com更新 acme.sh升级acme.sh到最新版:acme.sh --upgrade开启自动升级:acme.sh --upgrade --auto-upgrade关闭自动更新:acme.sh --upgrade --auto-upgrade 0
2022年03月29日
46 阅读
0 评论
0 点赞
2022-03-24
PHP json_encode函数的参数说明与用法
php使用json_encode()函数可以把数组,对象转化成JSON格式的字符串,用于和其它页面的数据交互。今天就说一说PHP中json_encode()函数的定义与使用方法。函数定义json_encode():可以把数组,对像转化成json格式的字符串json_encode ( value,options,depth)参数:value:要被转换的数据,可以是对象,数组或字符串options:二进制常量,规定一些要转换的字符串的形式(具体,看文未说明)depth:设置最大深度。 必须大于0。注意:depth 参数在一些文档或教材中是不存在,但在PHP官方文档中是有介绍的,在平时,不建议使用,略过即可。数组转json利用 json_encode(函数,可以很轻松的将一维数组,以及二维数组转换成 JSON 字符串,如以下的示例代码。转化一维数组示例代码:<?php // William's Blog // 一维数组转成JSON $arr = array( 'Name' => 'iyume', 'PageHome' => 'http://blog.iyume.top', ); var_dump(json_encode($arr)); ?>由于json_encode()函数返回的结果是字符串形式的,可以利用var_dump()函数来打印转化二维数组示例代码:<?php // William's Blog // 二维数组转成JSON $arr = array( 'Name' => 'iyume', 'PageHome' => 'http://blog.iyume.top', 'About' => array( 'Major' => 'PHP', 'Age' => '18', 'Address' => 'Shang Hai', ), ); var_dump(json_encode($arr)); ?>打印结果:string(113) "{"Name":"iyume","PageHome":"http:\/\/blog.iyume.top","About":{"Major":"PHP","Age":"18","Address":"Shang Hai"}}"中文不转码<?php // William's Blog $arr = array( 'Name' => '云梦', 'PageHome' => '云梦博客', ); var_dump(json_encode($arr, JSON_UNESCAPED_UNICODE)); ?>options 参数列表JSON_HEX_TAG所有的 < 和 > 转换成 \u003C 和 \u003E。 自 PHP 5.3.0 起生效。JSON_HEX_AMP所有的 & 转换成 \u0026。 自 PHP 5.3.0 起生效。JSON_HEX_APOS所有的 ' 转换成 \u0027。 自 PHP 5.3.0 起生效。JSON_HEX_QUOT所有的 " 转换成 \u0022。 自 PHP 5.3.0 起生效。JSON_FORCE_OBJECT使一个非关联数组输出一个类(Object)而非数组。 在数组为空而接受者需要一个类(Object)的时候尤其有用。 自 PHP 5.3.0 起生效。JSON_NUMERIC_CHECK将所有数字字符串编码成数字(numbers)。 自 PHP 5.3.3 起生效。JSON_PRETTY_PRINT用空白字符格式化返回的数据。 自 PHP 5.4.0 起生效。JSON_UNESCAPED_SLASHES不要编码 /。 自 PHP 5.4.0 起生效。JSON_UNESCAPED_UNICODE以字面编码多字节 Unicode 字符(默认是编码成 \uXXXX)。 自 PHP 5.4.0 起生效。连在一起可以是:echo json_encode($array, JSON_NUMERIC_CHECK | JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);
2022年03月24日
27 阅读
0 评论
0 点赞
2022-03-14
wget 批量下载
wget -r -np -nd http://example.com/packages/这条命令可以下载 http://example.com 网站上 packages 目录中的所有文件。其中,-np 的作用是不遍历父目录,-nd 表示不在本机重新创建目录结构。wget -r -np -nd --accept=iso http://example.com/centos-5/i386/与上一条命令相似,但多加了一个 --accept=iso 选项,这指示 wget 仅下载 i386 目录中所有扩展名为 iso 的文件。你也可以指定多个扩展名,只需用逗号分隔即可。wget -i filename.txt此命令常用于批量下载的情形,把所有需要下载文件的地址放到 filename.txt 中,然后 wget 就会自动为你下载所有文件了。wget -c http://example.com/really-big-file.iso这里所指定的 -c 选项的作用为断点续传。wget -m -k (-H) http://www.example.com/该命令可用来镜像一个网站,wget 将对链接进行转换。如果网站中的图像是放在另外的站点,那么可以使用 -H 选项
2022年03月14日
27 阅读
0 评论
0 点赞
2022-03-11
uPic 配置自定义图床教程
配置项说明API 地址: 后台服务 URL请求方式: 后台服务请求方式,支持POST和PUT文件字段名: 上传表单中的,文件对象的字段名扩展字段: Request Body。点击其他字段按钮进行配置请求头: Request Headers。点击其他字段按钮进行配置URL 路径: 上传完成返回的 JSON 中图片 URL 的获取路径。获取规则域名: 上传过后,访问服务器文件的 URL。保存路径: 文件储存的路径(包括文件夹)。 支持 {year} {month} {day} {hour} {minute} {second} {since_second} {since_millisecond} {random} {filename} {.suffix} 等变量。比如:上传的图片为 uPic.jpg,设定为 “uPic/{filename}{.suffix}”,则会保存到 “uPic/uPic.jpg”。在保存路径输入框后面的是网址后缀: 可以用于自定义图片处理。URL 获取规则Demo1{ "data": "http://xxx.png" } # 获取 ["data"]Demo2{ "data": { "url": "http://xxx.png" } } # 获取 ["data", "url"]Demo3{ "data": { "url": [ "http://xxx.png" ] } } # 获取 ["data", "url", 0]Demo4{ "data": [ { "url": "http://xxx.png" } ] } # 获取 ["data", 0, "url"]动态模板值{message type="success" content="扩展字段和请求头都支持以下动态模板来获取动态值"/}{filename}:会以上传时的文件名动态替换温馨提示1、请求头中的Content-Type 一定要设为 multipart/form-data; charset=utf-8;,否则很有可能服务端无法处理这个数据。2、接口返回的必须是包含图片地址的JSON文件,因为uPic是从这个文件里读取数据的,返回text无效。
2022年03月11日
93 阅读
0 评论
0 点赞
2022-03-08
百度网盘获取BDUSS和STOKEN方法
百度网盘下载速度是出名的渣,找一个有VIP账号的朋友,让他们提供一下 BUDSS + STOKEN,用代码发送请求使用。操作方法1、使用 Chrome 浏览器登录百度网盘网页版 https://pan.baidu.com 2、查看当前使用的 cookie 3、获取BDUSS 4、获取STOKEN
2022年03月08日
486 阅读
0 评论
0 点赞
1
...
4
5
6
...
18