Lost?
+This page does not exist.
+diff --git a/public/404.html b/public/404.html new file mode 100644 index 0000000..285b724 --- /dev/null +++ b/public/404.html @@ -0,0 +1,133 @@ + + + +
+This page does not exist.
+前言 又是新的一年,时间流速感觉越来越快了。
+前言 中文和英语发音习惯不同,容易引起误解。本文旨在帮助您准确发音常见的科技术语,欢迎随时补充。
+ +常见发音错误指南:公司/产品名
+Youtube: 正确念法是 "You-tube" [tju:b],而不是 "优吐毙",应该是 "优tiu啵"。
+Skype: 应该念为 [ˈskaɪp],而不是 "死盖屁",应该是 "死盖破"。
+Adobe: 正确的发音是 [əˈdəʊbi],不是 "阿斗伯",而是 "阿兜笔"。
+C#: 应该念为 "C Sharp",即"C煞破"。
+GNU: 正确的发音是 [(g)nuː], 即"哥怒"。
+GUI: 应该念为 [ˈɡui],即"故意"。
+JAVA: 正确的发音是 [ˈdʒɑːvə],而不是 "夹蛙",应该是 "扎蛙"。
+AJAX: 应该念为 [ˈeɪdʒæks],而不是 "阿贾克斯",应该是 "诶(ei) 贾克斯"。
+Ubuntu: 正确的发音是 [uˈbuntuː],而不是 "友邦兔",应该是 "巫不恩兔"。
+Debian: 应该念为 [ˈdɛbiən],即"得(dei)变"。
+Linux: 正确的发音有两种,[ˈlɪnəks] 或 [ˈlɪnʊks],"丽娜克斯" 或 "李扭克斯"都可以。
+LaTeX: 正确的发音是 [ˈleɪtɛk] 或 [ˈleɪtɛx] 或 [ˈlɑːtɛx] 或 [ˈlɑːtɛk],即"雷泰克" 或 "拉泰克"。
+GNOME: 念法可以是 [ɡˈnoʊm] 或 [noʊm],即"格弄姆" 或 "弄姆"。
+App: 应该念为 [ˈæp],即 "阿破"。
+null: 正确的发音是 [nʌl],即"闹"。
+jpg: 应该念为 [ˈdʒeɪpɛɡ],而不是 "勾屁记",应该是 "zhei派个"。
+WiFi: 正确的发音是 [ˈwaɪfaɪ],即"歪fai"。
+mobile: 念法可以是 [moˈbil] 或 [ˈmoˌbil] 或 [ˈməubail],即"膜拜哦" 或 "牟bou"。
+integer: 正确的发音是 [ˈɪntɪdʒə],而不是 "阴太阁儿",应该是 "音剃摺儿"。
+cache: 应该念为 [kæʃ],而不是 "卡尺",即"喀什"。
+@: 应该念为 "at"。
+Tumblr: 应该念为 "Tumbler",而不是 "贪不勒"。
+nginx: 正确的发音是 "Engine X",应该是 "恩静 爱克斯"。
+Apache: 应该念为 [əˈpætʃiː],即"阿趴气"。
+Lucene: 正确的发音是 [ˈluːsin],即"鲁信"。
+MySQL: 应该念为 [maɪ ˌɛskjuːˈɛl] 或 [maɪ ˈsiːkwəl],可以是 "买S奎儿" 或 "买 吸扣"。
+Exposé: 念法可以是 [ɛksˈpəʊzeɪ],重音在Z上。
+RFID: 官方念法是四个字母分开读 "R F I D"。
+JSON: 应该念为 "jason",即"zhei森"。
+Processing: 重音在 "Pro" 上。
+avatar: 正确的发音是 [ˌævə'tɑr],即"艾瓦塌儿"。
+虽然许多的词汇常常被错误发音,但在中国遵守拼音原则是入乡随俗的一种表现,且往往并没有所谓的官方读法,不必太过于纠结100%纯正的读法。
+ +前言 BACI是一个简化的并发程序模拟器,这里对其语法与运行环境进行说明。
+ +BACI(Ben-Ari Concurrent Interpreter)由计算机科学家 M. Ben-Ari 开发,是一个用于教学目的的并发程序模拟器,提供了一个简化的编程环境,使学习者能够编写、编译和执行并发程序,从而深入理解进程同步、互斥、信号量等核心概念。
BACI C−− User’s Guide:详细介绍了 C−− 编译器(bacc)与 PCODE 解释器(bainterp)的使用方法、语法说明及示例程序。该指南包含编译命令、信号量、监视器等并发原语介绍。 这里对官方文档进行了汉化:
++作者:Bill Bynum/Tracy Camp 威廉玛丽学院/科罗拉多矿业学院 2002年11月5日
+
1. 引言
+2. C-- 编译器语法
+3. 并发结构
+ 3.1 cobegin 块
+ 3.2 信号量
+ 3.2.1 初始化信号量
+ 3.2.2 p (或 wait) 和 v (或 signal) 函数
+ 3.2.3 信号量使用示例
+ 3.3 管程
+ 3.3.1 条件变量
+ 3.3.2 waitc 和 signalc 函数
+ 3.3.3 立即恢复要求
+ 3.3.4 管程示例
+ 3.4 其他并发结构
+ 3.4.1 atomic 关键字
+ 3.4.2 void suspend( void );
+ 3.4.3 void revive( int process_number );
+ 3.4.4 int which_proc( void );
+ 3.4.5 int random( int range );
+4. 内置字符串处理函数
+ 4.1 void stringCopy(string dest, string src);
+ 4.2 void stringConcat(string dest, string src);
+ 4.3 int stringCompare(string x, string y);
+ 4.4 int stringLength(string x);
+ 4.5 int sscanf(string x, rawstring fmt,...);
+ 4.6 void sprintf(string x, rawstring fmt,...);
+5. 使用 BACI C-- 编译器和 PCODE 解释器
+6. 示例程序和输出
+
+本文档旨在简要描述 C-- BACI 编译器和并发 PCODE 解释器程序,并说明如何使用它们。C-- 编译器首先将用户程序编译成一种称为 PCODE 的中间目标代码,然后由解释器执行。C-- 编译器支持二进制和计数信号量以及 Hoare 管程。解释器模拟并发进程执行。
+BACI 系统程序:
+| 程序 | 功能 | 相关文档 |
|---|---|---|
| bacc | BACI C-- 到 PCODE 编译器 | 本指南 (cmimi.ps) |
| bapas | BACI Pascal 到 PCODE 编译器 | guidepas.ps |
| bainterp | 命令行 PCODE 解释器 | cmimi.ps, guidepas.ps, disasm.ps |
| bagui | PCODE 解释器的图形用户界面(仅限 UNIX 系统) | guiguide.ps |
| badis | PCODE 反编译器 | disasm.ps |
| baar | PCODE 归档程序 | sepcomp.ps |
| bald | PCODE 链接器 | sepcomp.ps |
Pascal 版本的编译器和解释器最初是 M. Ben-Ari 编写的程序中的过程,基于 Niklaus Wirth 的原始 Pascal 编译器。程序源代码作为附录包含在 Ben-Ari 的著作《并发编程原理》中。BACI 编译器和解释器的原始版本就是从该源代码创建的。最终,Pascal 编译器和解释器被分成两个独立的程序,并开发了 C-- 编译器,用于将用 C++ 的受限子集编写的源程序编译成可由解释器执行的 PCODE。
+下面将解释 C-- 编译器的语法。本指南仅适用于 C-- 编译器,不适用于 BACI 并发 Pascal 编译器。对 Pascal 编译器感兴趣的用户应参考其用户指南(见文件 guidepas.ps)。
+如同 C++,注释可以用 '/' 和 '/' 或 '//' 来界定。
+除了标准输入和输出外没有其他文件:cout、cin 和 endl 在 C-- BACI 中的行为与标准 C++ 一致。主程序必须具有以下形式之一:
+int main()
+void main()
+main()
+
+C-- BACI 中唯一可用的简单 C/C++ 类型是 int 和 char。还有其他与并发控制相关的类型,将在下面讨论。
+所有变量必须在它们出现的代码块开头声明。特别是,for 循环的索引变量不能在循环头中声明,而必须在包含该 for 循环的块的开头声明。
+支持 string 类型。声明字符串时,必须指定字符串的长度。以下声明定义了一个长度为 20 的字符串:
+string[20] string_name;
+
+长度说明符应该是字符串应具有的字符数,不应包括终止字节的空间。编译器负责为终止字节保留空间。长度说明符必须是字面常量或程序常量。
+在函数声明中,string 关键字用于声明 string 类型的参数:
+void proc(string formal_parm)
+
+此声明断言 formal_parm 的类型为 string[n],其中 n 为某个正值。string 类型的参数是通过引用传递的。不执行字符串溢出检查。
+支持任何有效类型的数组。数组声明遵循通常的 C 语法:
+element_type arrayname[index1][index2][index3]...[indexN];
+
+C-- BACI 支持关键字 typedef。例如,要使变量名 length 成为 int 的同义词:
+typedef int length;
+
+支持简单类型的常量 (const):
+const int m = 5;
+
+在声明 int 和 char 类型的变量时,支持初始化器。初始化器的值必须是字面量或程序常量:
+const int m = 5;
+int j = m;
+int k = 3;
+char c = 'a';
+
+支持过程和函数。适用标准作用域规则。支持递归。参数声明为传值或传引用:
+int afunc(int a, /* 传值 */
+ int& b) /* 传引用 */
+
+每个程序必须有一个 int 或 void 类型的 main() 函数,并且该函数必须是源文件中的最后一个函数。执行从 main() 的调用开始。
+可执行语句包括 if-else、switch/case、for、while、do-while、break 和 continue。这些语句的语法与标准 C/C++ 相同。代码的括号也是标准的,即 { ... }。
+支持标准 C/C++ 文件包含:
+#include < ... >
+#include " ... "
+
+两种包含语句风格具有相同的语义,因为没有"系统"包含目录。
+支持用于定义外部变量的 extern 关键字。外部变量可以是任何有效的 C-- 类型。外部变量不能使用初始化器。extern 关键字只能出现在全局("外部")级别。典型示例:
+extern int i;
+extern char a[20];
+extern string[30] b;
+// 不允许初始化器 ----> extern int i = 30;
+// (如果有初始化,必须在 i 定义的地方进行)
+extern int func(int k);
+extern monitor monSemaphore { // 见第 3 节。这里只需给出
+ void monP(); // 管程的外部可见细节
+ void monV();
+}
+
+使用 bacc 编译包含外部引用的源文件时,必须使用 -c 选项。有关使用外部变量的更多信息,请参阅 BACI 系统分离编译指南。
+C-- 进程是一个 void 函数。在 BACI 系统中,"并发进程"一词与"并发线程"一词同义。要并发运行的进程列表封装在一个 cobegin 块中。这种块不能嵌套,必须出现在主程序中。
+cobegin {
+ proc1(...); proc2(...); ... ; procN(...);
+}
+
+列出的过程中的 PCODE 语句由解释器以任意的"随机"顺序交错执行,因此,包含 cobegin 块的同一程序的多次执行将表现为非确定性的。主程序被挂起,直到 cobegin 块中的所有进程终止,此时主程序在块结尾后的语句处恢复执行。
+解释器有一个预先声明的 semaphore 类型。也就是说,C-- 中的信号量是一个非负整数变量(见下面的定义),只能以受限方式访问。二进制信号量,即只取值 0 和 1 的信号量,由 semaphore 类型的 binarysem 子类型支持。在编译和执行过程中,编译器和解释器强制限制 binarysem 变量只能取值 0 或 1,而 semaphore 类型只能是非负的。
+只有在定义信号量变量时才允许对其赋值。例如,以下任一声明都是有效的:
+semaphore s = 17;
+binarysem b = 0;
+
+内置过程:
+initialsem(semaphore, integer_expression);
+
+是在运行时初始化任一类型信号量的唯一可用方法。在调用中,integer_expression 可以是计算结果为整数且对信号量类型有效的任何表达式(semaphore 类型为非负,binarysem 类型为 0 或 1)。例如,以下两个 initialsem 调用显示了初始化上述两个信号量的另一种方式:
+initialsem(s, 17);
+initialsem(b, 0);
+
+p 函数(或同义的 wait)和 v 函数(或同义的 signal)由并发执行的进程用于同步它们的操作。这些函数为用户提供了更改信号量值的唯一方式。
+这两个函数的原型如下:
+void p(semaphore& s);
+
+或等效地:
+void wait(semaphore& s);
+
+以及:
+void v(semaphore& s);
+
+或等效地:
+void signal(semaphore& s);
+
+每个函数的信号量参数显示为引用参数,因为函数会修改信号量的值。
+p 和 v 函数调用的语义如下:
+p(sem);
+v(sem);
+为帮助解释信号量的使用,我们提供以下简短示例:
+BACI System: C-- to PCODE Compiler, 09:24 2 May 2002
+Source file: semexample.cm Sun Apr 28 20:40:12 2002
+line pc
+1 0 // C-- 信号量使用示例
+2 0
+3 0 semaphore count; // 一个"通用"信号量
+4 0 binarysem output; // 一个二进制(0 或 1)信号量,用于解除输出混乱
+5 0
+6 0 void increment()
+7 0 {
+8 0 p(output); // 获取对标准输出的独占访问权
+9 2 cout << "before v(count) value of count is " << count << endl;
+10 6 v(output);
+11 8 v(count); // 增加信号量
+12 10 } // increment
+13 11
+14 11 void decrement()
+15 11 {
+16 11 p(output); // 获取对标准输出的独占访问权
+17 13 cout << "before p(count) value of count is " << count << endl;
+18 17 v(output);
+19 19 p(count); // 减少信号量(或停止 -- 见手册文本)
+20 21 } // decrement
+21 22
+22 22 main()
+23 23 {
+24 23 initialsem(count,0);
+25 26 initialsem(output,1);
+26 29 cobegin {
+27 30 decrement(); increment();
+28 36 }
+29 37 } // main
+
+该程序使用两个信号量。一个信号量 count 属于 semaphore 类型,这向 BACI 系统表明该信号量将被允许具有任何非负值。两个并发过程 increment 和 decrement 通过 count 信号量相互"发送信号"。另一个信号量 output 属于 binarysem 类型,这向 BACI 系统表明该信号量应始终具有值 0 或 1;任何其他值都会导致运行时异常。该信号量用于防止两个并发执行的过程 increment 和 decrement 的输出混合在一起。
+我们使用以下命令生成上述编译器列表:
+prompt% bacc semexample
+Pcode and tables are stored in semexample.pco
+Compilation listing is stored in semexample.lst
+
+然后可以使用 BACI PCODE 解释器执行 semexample.pco 文件:
+prompt% bainterp semexample
+Source file: semexample.cm Sun Apr 28 20:40:12 2002
+Executing PCODE ...
+before v(count) value of count is 0
+before p(count) value of count is 1
+
+这是程序可能产生的三种可能输出之一。另外两种可能的程序输出是:
+prompt% bainterp semexample
+Source file: semexample.cm Sun Apr 28 20:40:12 2002
+Executing PCODE ...
+before p(count) value of count is 0
+before v(count) value of count is 0
+
+prompt% bainterp semexample
+Source file: semexample.cm Sun Apr 28 20:40:12 2002
+Executing PCODE ...
+before v(count) value of count is 0
+before p(count) value of count is 0
+
+有兴趣的读者可能会发现,提供这三种程序输出生成方式的解释,并证明这三种输出是唯一可能的输出,是很有指导意义的。
+支持 Hoare 提出的管程概念,但有一些限制。管程是一个 C-- 块,类似于由过程或函数定义的块,但具有一些额外的属性。管程块中的所有函数都是可见的(即可从块外部调用的入口过程),但管程变量在块外部不可访问,并且只能由管程函数访问。
+在 C-- 中,管程只能在最外层、全局级别声明。管程不能嵌套。管程可以选择在最后一个块中有一个 init{} 块,用于初始化管程变量的值。这段代码在主程序启动时运行。
+管程块的只有一个过程或函数可以在任何时候执行。这一特性使得可以使用管程来实现互斥。使用管程控制并发是有优势的,因为所有控制并发的代码都位于管程中,而不是像使用信号量那样广泛分布在调用者中。
+管程的过程和函数使用三种结构来控制并发:条件变量、waitc(等待条件)和 signalc(表示条件)。
+条件变量只能在管程中定义,因此只能由管程的进程访问。条件变量实际上从不"有"值;它是等待的地方或信号的东西。管程进程可以通过 waitc 和 signalc 调用等待条件成立或表示给定条件现在成立。
+waitc 和 signalc 调用具有以下语法和语义:
+void waitc(condition cond, int prio);
+
+管程进程(因此,也是调用管程进程的外部进程)被阻塞并被分配优先级 prio 以便被重新唤醒(见下面的 signalc)。请注意,这种阻塞操作允许另一个管程进程执行,如果有的话。
+void waitc(condition cond);
+
+此调用具有与上面的 waitc 调用相同的语义,但等待被分配默认优先级 10。
+void signalc(condition cond);
+
+唤醒在 cond 上等待的、具有最小(最高)优先级的某个进程;否则,不执行任何操作。请注意,这与信号量 v 或 signal 完全不同,因为如果没有人等待,signalc 是一个空操作,而 v(sem) 在没有人等待时会增加 sem,从而在将来的 p(sem) 发生时"记住"该操作。
+优先级方案可用于实现重新唤醒等待者的 FIFO 规则。如果每个管程进程都增加与当前分配给条件的优先级相关联的管程变量,那么对该条件的连续 signalc 将按照 FIFO 顺序唤醒休眠进程。
+C-- 编译器提供了一个 int 函数 empty(cond),如果条件 cond 的队列中没有进程等待,则返回 1,否则返回 0。
+这是指刚刚被发送信号的条件上等待的进程应该优先于新调用管程进程(那些想要"从顶部"进入的进程)重新进入管程的要求。该要求基于这样的假设:刚刚被发送信号的条件比新进入管程的情况具有更"紧急"的业务要执行。立即恢复要求在 BACI 中通过挂起条件的发送者并随机选择一个具有适当优先级的条件等待者来运行来实现。因此,signalc 条件的管程过程通常将其作为最后一条指令。
+当被 signalc 重新唤醒的进程离开管程时,在发出 signalc 调用后被挂起的在管程中执行的进程被允许优先于尝试"从顶部"进入管程的进程恢复在管程中的执行。
+以下通过管程实现通用信号量的示例说明了管程语法:
+monitor monSemaphore {
+ int semvalue;
+ condition notbusy;
+ void monP()
+ {
+ if (!semvalue)
+ waitc(notbusy);
+ else
+ semvalue--;
+ }
+ void monV()
+ {
+ if (empty(notbusy))
+ semvalue++;
+ else
+ signalc(notbusy);
+ }
+ init{ semvalue = 1; }
+} // monSemaphore 管程结束
+
+BACI C-- 提供了几个低级并发结构,可用于创建新的并发控制原语:这些函数可用于创建"公平"(FIFO)队列信号量。实现这一点的代码超出了本用户指南的范围。
+如果一个函数被定义为 atomic,那么该函数是不可抢占的。解释器不会用上下文切换中断一个原子函数。这为用户提供了定义新原语的方法。以下程序说明了如何定义 test_and_set 原语并使用它来强制互斥:
+atomic int test_and_set(int& target) {
+ int u;
+ u = target;
+ target = 1;
+ return u;
+}
+
+int lock = 0;
+
+void proc(int id) {
+ int i = 0;
+ while(i < 10) {
+ while (test_and_set(lock)) /* wait */ ;
+ cout << id;
+ lock = 0;
+ i++;
+ }
+}
+
+main() {
+ cobegin { proc(1); proc(2); proc(3); }
+}
+
+suspend 函数使调用线程休眠。
+revive 函数重新激活给定编号的进程。
+which_proc 函数返回当前线程的进程编号。
+random 函数返回一个在 0 到 range - 1(包含)之间"随机选择"的整数。它使用与解释器使用的不同的随机数生成器流;也就是说,random() 调用不会影响解释器执行。
+stringCopy 函数将 src 字符串复制到 dest 字符串中。不执行字符串溢出检查。例如:
+string[20] x;
+...
+stringCopy(x,"Hello, world!");
+stringCopy(x,"");
+
+将把字符串 x 初始化为一个众所周知的值。第二个 stringCopy 将字符串 x 重置为零长度字符串。
+stringConcat 函数将 src 字符串连接到 dest 的末尾。不执行字符串溢出检查。
+stringCompare 函数与 C 字符串库中的 strcmp 函数具有相同的语义:如果字符串 x 按字典顺序在字符串 y 之后,则返回正数;如果字符串相等,则返回零;如果字符串 x 按字典顺序在字符串 y 之前,则返回负数。
+stringLength 函数返回字符串 x 的长度,不包括终止字节。
+与"真正的" sscanf 一样,sscanf 函数根据格式字符串 fmt 扫描字符串 x,将扫描到的值存储到参数列表中提供的变量中,并返回扫描到的项目数。仅支持真正的 sscanf 的 %d、%x 和 %s 格式说明符。还支持 BACI 独有的附加格式说明符 %q(带引号的字符串)。对于此说明符,所有由一对双引号(")分隔的字符都将被扫描到相应的字符串变量中。当在格式字符串中遇到 %q 说明符时,如果要扫描的字符串中的下一个非空白字符不是双引号,则 %q 扫描失败,并且字符串的扫描终止。
+格式字符串后面出现的变量是引用变量(即,不需要 & 符号)。
+在以下示例中,sscanf 调用返回的 i 值将为 4,存储在变量 j 中的值将为 202,存储在字符串 x 中的字符串值将为 alongstring,存储在变量 k 中的值将为 0x3c03,存储在字符串 y 中的字符串将为 a long string。
+string[50] x,y;
+int i,j,k;
+stringCopy(x,"202 alongstring 3c03 \"a long string\"");
+i = sscanf(x,"%d %s %x %q",j,x,k,y);
+
+与 C 库中的"真正的" sprintf 函数一样,sprintf 函数使用格式字符串 fmt 和格式字符串后面的变量创建存储在变量 x 中的字符串。
+支持 %d、%o、%x、%X、%c 和 %s 格式说明符,其全部功能与真正的 sprintf 相同。此外,%q 格式说明符将在输出字符串中插入带双引号的字符串。%q 格式说明符等同于 "%s" 说明符。
+例如,在以下代码片段中:
+string[80] x;
+string[15] y,z;
+stringCopy(y,"alongstring");
+stringCopy(z,"a long string");
+sprintf(x,".%12d. .%-20s. .%q. .%08X.",202,y,z,0x3c03);
+
+字符串 x 变为:
+. 202. .alongstring . ."a long string". .00003C03.
+
+使用 BACI 系统执行程序有两个步骤。
+编译 ".cm" 文件以获取 ".pco" 文件。
+用法:bacc [可选标志] 源文件名
+可选标志:
+-h 显示此帮助
+-c 创建一个 .pob 目标文件以便后续链接
+
+源文件名是必需的。如果缺少,您将被提示输入。如果您不提供,将附加文件后缀 ".cm"。
+解释 ".pco" 文件以执行程序
+用法:baininterp [可选标志] pcode文件名
+可选标志:
+-d 进入调试器,单步执行,设置断点
+-e 在进入每个进程时显示活动记录 (AR)
+-x 在退出每个进程时显示 AR
+-t 宣布进程终止
+-h 显示此帮助
+-p 显示正在执行的 PCODE 指令
+
+PCODE 文件名是必需的。如果缺少,您将被提示输入。文件后缀 ".pco" 将附加到您给出的文件名。
+每次用 bainterp 执行 .pco 文件时,不必重新编译源文件。有一个 shell 脚本 baccint,它将为您调用编译器,然后调用解释器。它会将您给它的选项(见上文)传递给解释器。
+以下列表由 C-- BACI 编译器生成。行号右侧的数字是开始该行的指令的 PCODE 偏移量。BACI 编译器从文件 "incremen.cm" 创建此列表。该列表被放置在文件 "incremen.lst" 中。还创建了一个 "incremen.pco" 文件;此文件由解释器使用。
+BACI System: C-- to PCODE Compiler, 09:24 2 May 2002
+Source file: incremen.cm Wed Oct 22 21:18:02 1997
+line pc
+1 0 const int m = 5;
+2 0 int n;
+3 0
+4 0 void incr(char id)
+5 0 {
+6 0 int i;
+7 0
+8 0 for(i = 1; i <= m; i = i + 1)
+9 14 {
+10 14 n = n + 1;
+11 19 cout << id << " n =" << n << " i =";
+12 25 cout << i << " " << id << endl;
+13 31 }
+14 32 }
+15 33
+16 33 main()
+17 34 {
+18 34 n = 0;
+19 37 cobegin
+20 38 {
+21 38 incr( 'A'); incr( 'B' ); incr('C');
+22 50 }
+23 51 cout << "The sum is " << n << endl;
+24 55 }
+
+以下列表由 BACI 解释器生成。解释器执行编译到文件 "incremen.pco" 中的程序。
+Source file: incremen.cm Wed Oct 22 21:18:02 1997
+Executing PCODE ...
+C n =1 i =A n =1 C2 i =
+1 A
+C n =4 i =2 C
+B n =A n =5 i =24 A
+i =1 B
+AC n = n =6 i =3 C6 i =3
+A
+C n =7 i =4 C
+B n =9 i =2 BA n =8
+i =4 A
+C n =8 i =5 A n =9C
+i =5 A
+B n =10 i =3 B
+B n =11 i =4 B
+B n =12 i =5 B
+The sum is 12
+
+apt install jdk-openjdk dos2unix
+
+dos2unix ~/Git/java/baci/scripts/baci
+
+#!/usr/bin/env bash
+# 定位到项目根目录(包含 javabaci 子目录的目录)
+BASEDIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)"
+
+# 将 javabaci/bin(默认包类)和项目根目录(javabaci 包根)加入 classpath
+CLASSPATH="$BASEDIR/javabaci/bin:$BASEDIR"
+
+# 将所有参数原样传递给 java 运行
+exec java -cp "$CLASSPATH" "$@"
+
+chmod +x ~/Git/java/baci/scripts/baci
+
+fish_add_path ~/Git/java/baci/scripts
+
+which baci
+
+baci bacc ex3_1.cm
+baci bainterp ex3_1
+
+Done.
+ +前言 个人博客的搭建具有许多的方案可以选择,本文介绍如何快速部署一个博客,并将其发布到公网。
+在互联网冲浪的过程中,我们常常看到许多独立站点,他们往往是个人博客,有各种各样的主题样式;这些站点见证了互联网的发展历史。从最初的手工编写HTML页面,到后来的内容管理系统(CMS)如WordPress的兴起,再到如今流行的静态网站生成器(SSG),如Hugo,Hexo,Zola等等。
+个人博客的定义是什么?私以为是域名+站点+原创内容三要素组成。当然,最重要的原创内容往往被忽视...
eu.org或us.kg等免费域名,目的是为了好记;WordPress或者Halo来一键创建,也可以使用静态框架部署在PAAS平台上;因此,整体成本应该是非常低的。
+curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o quick_start.sh && sudo bash quick_start.sh
+
+++1panel依赖于docker,如果实现没有安装docker,脚本会帮你安装。
+
安装过程中选择好端口,随后即可使用http:<ip>:<port>:<安全入口>进入登录界面,并使用默认随机生成的密码进入面板。
进入之后我们可以看到里面有应用商店,在其中安装OpenResty与Halo与mysql,安装完毕后打开外部访问地址http://ip:8090,即可进入halo的后台,在其中写入文章并发布。
但我们不能使用不安全的HTTP以及IP来访问博客;因此,我们需要一个域名指向我们的博客,例如本文的blog.dich.bid;可以在在Dynadot等平台购买域名,并托管到Cloudflare。
随后可以在1panel的网站中创建一个反向代理,代理地址即为http://ip:8090,主域名为刚刚注册的域名前加blog或其他,如blog.xxx.com
创建完成后我们还需要配置TLS证书,在网站-HTTPS中添加证书,可以选择自签名证书正式或者通过Acme申请免费的Let's Encrypt证书。
配置完成后在Cloudflare的DNS解析界面创建一个A记录,将你的blog.xxx.com解析到你的服务器的IP;
大功告成!现在你应该可以通过HTTPS域名访问自己的博客!
+首先明确你需要的架构,一般有两种选择:
+++可以在这个网站上面查看常见的框架与主题的显示效果
+
# 打开以管理员模式运行的PowerShell,输入命令安装 Hugo Extended:
+winget install Hugo.Hugo.Extended
+
+paru -S hugo
+
+hugo version
+
+hugo new site myblog
+
+该命令会在myblog文件夹下生成hugo的基础目录。
cd myblog
+git clone https://github.com/hugo-sid/hugo-blog-awesome.git themes/hugo-blog-awesome
+
+并在hugo.toml顶层添加:
theme = "hugo-blog-awesome"
+
+这样 Hugo 在构建时会从 themes/ 目录加载主题文件。后续可使用git pull获取主题更新。
++你也可以直接用theme中的文件夹替换掉项目根目录下的同名文件夹,并再次修改。
+
hugo new posts/hello-world.md
+
+该命令会在content/posts/下生成 Markdown 文件,打开后修改title、date、tags等前缀然后撰写 Markdown 正文, Markdown 编辑器参考前文。
++注意md文章头部和正文之间得使用
+<!-- more -->隔断
hugo server -D
+
+然后在浏览器访问http://localhost:1313即可实时预览并查看更新效果。
上传到GitHub:新建一个Github仓库,用Git连接并将Hugo项目的文件夹push上去;
+使用PAAS平台部署:随后使用Vercel/Netlify等平台读取GitHub仓库并部署Hugo博客项目,并设置指向自己的域名,即设置一条CNAME记录。部署的时候可以让平台command运行部署也可以本地build之后直接上传public文件夹并在平台中指定。
++当然,也可以使用GitHub Pages部署,详见官方文档
+
你想要的显示效果?
+你需要那些功能?
+需要处理哪些外部依赖?
+以上的功能和需求是否对SEO和界面相应时间造成影响?
+由于我所使用的平台不支持zola,因此我直接在本地编译public并推送,这样时间久了.git文件夹大小会非常大(记录public的变化),我又不想将zola的二进制包放入目录下,因此有了这个办法:
+# 安装git-filter-repo工具
+paru git-filter-repo
+# 清理public相关的历史
+git clone git@github.com:Dichgrem/Blog.git blog1 && cd blog1
+git filter-repo --path public --invert-paths
+git gc --aggressive --prune=now
+# 重新推送到github
+git push --force --mirror
+
+Done.
+ +前言 由于临近升学,校园网不尽人意,因此许多小伙伴有了买一张流量卡的计划。本文以三大运营商为例,说明常见流量卡的套路与选择。
+ +2019 年 6 月 6 日,工信部发布 4 张 5G 牌照,标志 5G 商用的开始,中国进入 5G 时代。回想过去数年,4G 降速、5G 提费的新闻屡见不鲜,而 5G 网络的落地应用,似乎离普通人依然遥远。对于普通人而言,昂贵的5G套餐资费依然没有流量卡香;那什么是流量卡呢?
+流量卡本质上还是一张 SIM 卡,往往具有大流量、低月租的特征。互联网上有非常多不同运营商的「优惠套餐」,实则是不同卡商取名包装后的产物,卡商往往可以通过激活后赚取高额佣金获利,比如每年大学新生开学,校园里总有「运营商营业厅」摆摊甚至上门推销所谓「校园卡」,不少声称「超大流量」「长期套餐」,更有甚者,会搬出「校园网」来给涉世未深的大一小白们制造焦虑。
事实上,不管是「校园卡」还是网上卡商们大力吆喝的优惠流量卡,本质上都属于个人使用的电话卡。例如电信的优惠套餐,大都通过「电信星卡」套餐,再由当地运营商叠加优惠包(赠费或叠加流量包)包装而成。
普通卡大多有着长合约和固定归属地,不能轻易更换套餐,且套餐月租费用较高,特别是在5G推行时期,4G的资费不减反升,且速度有所下降。而流量卡动则100G往上,月租在50左右,且可以随时退卡。
由于三大运营商处于半国企状态(自负盈亏),因此在长期亏损下不得不整一些牛马活采用一些策略,比如冗长的条款和隐藏极深的优惠套餐等等。而由于不同地区的经济发展状况不同,部分中西部地区的地区分公司业绩不佳,为了在短期内达到要求往往会和一些地区分销商进行合作,将本地区的电话卡改为优惠的套餐,从而吸引客户。注意:99%所谓的月租19、29等流量卡都是要先缴一笔较多的钱,进而每月返还一点点,实现长期上的低月租,运营商是要短期变现的!
那么,是不是我们就没有优惠了呢?其实相对于5元1G、40元10G的资费而言还是非常划算的。
+部分小伙伴反映被物联卡坑了!这里我们一定要注意,诸如某宝某猫上面的9999G超级流量卡,usb接口的随身WiFi等等不出意外都是物联卡。
+什么是物联卡?物联网设备往往只需要网络接入而不需要电话短信功能,也就不需要电话号码。为了防止滥用,同时降低成本,运营商往往会给这些设备制作「物联网卡」,也就是只具备上网功能的电话卡。为了便于物联网设备公司管理,运营商还会授权这些代理公司组建「流量池」,对池中每一张卡进行限速、流控等管理。
市面上绝大多数「随身 WiFi」自带的流量卡套餐,正是来自运营商授权公司的「自组流量池」。绝大多数物联卡商家,为了控制成本,会采取各种措施进行限制,而由于这一行业往往处于缺乏有效监管的灰色地带,这些限制大都不会被商家明确写出。
+最常见的套路是虚标流量。由于这类物联网卡并没有手机号码,也就无法使用运营商官方渠道查询流量使用情况。商家自建流量管理后台,也就有了对数据做手脚的可乘之机。有些商家会将使用的流量按 1.5 倍甚至更高倍率计费,因此,你也许会发现自己的流量不那么「经用」。
+另一个套路是流控,包括流量封顶和限速。网上销量相当高的某随身 WiFi 商家,电商平台可以看到不少次月开始卡慢、每日设置流量封顶的差评。比如,广告上打着「月享 1500G」,实际上也许每天限制使用 50G,达量往往会限速甚至封卡。
+在市面上,流量池批发流量的价格大约是 0.1 元 / G,如果你看到了显著低于这个价格的流量,可能需要多斟酌一下是否可靠。
+当然,也有正规厂商提供可信的流量池或与运营商直接合作的物联网卡,限制会少不少,不过难以买到。
+大部分流量卡是不能选号的,因为这类具有优惠套餐的卡大多来自不同地区的前任买家,因此靓号数有限,总不能既有好的号码又有优惠套餐;而这就带来第二个问题:
作为信息时代的重要识别符,电话卡和身份证几乎同样重要,在前任主人信息意识不强的情况下,其大部分社交媒体、生活服务和各种网站的帐号都会遗留下来,这就需要我们去一一解绑;作者曾经买了一张宁夏的流量卡,结果通过验证和社工成功进入了前主人的微信和淘宝帐号,当然现在已经注销了;部分平台不支持注销的,只能继续使用前号;甚至有概率被前号主的债务人打电话催债;因此我们一定要小心谨慎;
由于前面所讲的原因,流量卡的归属地大部分是随机的,比如青海,宁夏等等;这样一来当别人打电话时会看到地址为中国宁夏之类,可能会误以为是诈骗电话;当然这样也有不被看到地址的好处,所谓各有优点。
SIM卡本身对信号没有影响,除非氧化严重难以识别;真正影响体验的不只是手机基带,还有你所在地区中三大运营商的基站分布;因此,购买之前可以先查看一下你所在地区哪个运营商信号最好,从而对症下药。
有些小伙伴在买完流量卡后打算作为主力卡使用,那这样原先的卡套餐就没必要了,可以办理8元保号套餐,让号码可以继续使用。
+不少校园套餐,使用了定向流量(或区域流量),即仅可在指定APP使用或指定省(市)内使用,而非全国流量/通用流量。而宣传的额外流量往往以流量包形式给出,此流量包不同活动获得方式也不同;办完卡后进入营业厅的APP,流量可能不会马上出现,这是因为系统的延迟以及运营商的计时方式,有些卡需要在月初才能有全部的流量,后几天按百分比计算,下个月就正常了。
注意要实名购卡,且收获地址要足够详细,会有专门的快递小哥和你线下激活,预充值,注意接收电话!
每个运营商最多办5张电话卡,因此一个人一辈子最多只能从三大运营商办理一共15张卡,因此注销需谨慎;流量卡大部分可以线上异地注销,但也要仔细看清楚条款。
Done.
+ +前言 CSdiy珠玉在前,为CS教育做出了极大贡献.这里分享一些优质的CS学习相关视频.
+待续...
+ +前言 最近nekoray项目归档,考量新的singbox前端时发现这个项目不错,不过在Arch linux中运行有一些小问题,这里做个总结。
+安装gui-for-singbox的时候发现仓库的1.9.2版本release被作者删除,无法安装,于是:
+/opt/gui-for-singbox,运行sudo chown -R your_username:your_group /opt/gui-for-singbox,使其可以被非root用户启动;sudo setcap cap_net_bind_service,cap_net_admin,cap_dac_override=+ep /opt/gui-for-singbox/your_executable命令,并在设置-内核中点击盾牌-钥匙图标,使Tun模式可以有特权运行。systemctl status polkit
+
+sudo systemctl enable --now polkit
+
+sudo vi /etc/polkit-1/rules.d/99-nopassword.rules
+
+polkit.addRule(function (action, subject) {
+ if (
+ (action.id == "org.freedesktop.resolve1.set-domains" ||
+ action.id == "org.freedesktop.resolve1.set-default-route" ||
+ action.id == "org.freedesktop.resolve1.set-dns-servers") &&
+ subject.local &&
+ subject.active &&
+ subject.isInGroup("wheel")
+ ) {
+ return polkit.Result.YES;
+ }
+});
+
+sudo usermod -G wheel 当前用户
+
+sudo systemctl restart polkit
+
+Done.
+ +前言 Git,作为现代软件开发中不可或缺的版本控制工具,常常让初学者感到困惑。本文旨在介绍 Git 的全流程安装和基本使用,希望能够帮助新手更轻松地理解和掌握 Git 的基本概念和操作。
+Windows:Git-download
+Archlinux:sudo pacman -S git
一个Git仓库的目录里面包括工作目录(即我们要追踪的代码)以及.git目录(Git 在这里存储自己的数据)。Git 维护了三棵“树”:第一个是你的 工作目录,它持有实际文件;第二个是 暂存区(Index),它像个缓存区域,临时保存你的改动;最后是 HEAD,它指向你最后一次提交的结果。

首先我们需要得到一个Git仓库,一般有两种方法:
+方法一 +创建新文件夹,在你的项目目录中运行以下命令:
+git init --initial-branch=main
+
+这里设置默认仓库主分支名称为 main,避免因为 main/master 名称不同导致的推送问题。
+++Git目前默认的主分支为 master,和 github 默认分支 main 不同,这使得默认配置下 git 往往连接失败。除了创建的时候设定外还可以通过以下方法改变默认分支。
+
git config --global init.defaultBranch main //将默认分支修改成main
+
+方法二
+克隆远端服务器上的仓库:
+git clone https://github.com/Dichgrem/script.gitgit clone git@github.com:Dichgrem/script.git++建议使用SSH方法,如果你使用HTTPS方法,则提交代码时需要手动输入用户名/密码,使用SSH方法则只需要在
+~/.ssh/config中配置即可。
Git的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)。
+git config --list
+
+git config -e [--global]
+
+git config [--global] user.name "[name]"
+git config [--global] user.email "[email address]"
+
+git config core.ignorecase false
+
+git config --global core.editor "nvim"
+
+连接到远程仓库并推送需要证明你有权写入仓库。早期Github可以使用密码认证,现在则使用密钥认证。
+ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
+
+生成的文件位于~/.ssh/config路径下,带.pub后缀的文件为公钥,不带.pub后缀的为私钥,使用cat ~/.ssh/id_rsa.pub将公钥添加到github/gitee的设置-SSH中。
随后使用 ssh-add 命令将生成的密钥添加到 SSH 代理中。
ssh-add ~/.ssh/github_key
+ssh-add ~/.ssh/gitee_key
+
+~/.ssh/config 文件中配置不同的主机别名以及相应的密钥文件。编辑该文件并添加内容,例如:# GitHub repository 1
+
+Host github1
+
+ HostName github.com
+
+ User git
+
+ IdentityFile ~/.ssh/github_key
+
+# GitHub repository 2
+
+Host github2
+
+ HostName gitee.com
+
+ User git
+
+ IdentityFile ~/.ssh/gitee_key
+
+ssh -T git@github.com
+
+git remote add origin <remote_repository_url>
+
+# 例如:git remote add origin git@github.com:Dichgrem/dichos.git
+
+++如果你运行
+git remote -v发现URL为HTTP格式则可以用下面的命令改为Git格式:
# 例如:git remote set-url origin git@github.com:Dichgrem/dichos.git
+
+git branch main
+
+这将创建一个名为 main 的分支。
+git branch -d master
+
+git branch -D master
+
+你可以提出更改(把它们添加到暂存区),使用如下命令:
+git add <filename>
+git add *
+
+这是 git 基本工作流程的第一步;使用如下命令以实际提交改动:
+git commit -m "代码提交信息"
+# 例如:git commit -m "Initial commit"
+
+现在,你的改动已经提交到了 HEAD,但是还没到你的远端仓库。
+git add [file1] [file2] ...
+
+git add [dir]
+
+git add .
+
+添加每个变化前,都会要求确认
+git add -p
+
+git rm [file1] [file2] ...
+
+git rm --cached [file]
+
+git mv [file-original] [file-renamed]
+
+你的改动现在已经在本地仓库的 HEAD 中了。执行如下命令以将这些改动提交到远端仓库:
+git push origin main
+
+可以把 main 换成你想要推送的任何分支,如master或者test
+如果你的远程仓库是最新的,可以使用以下命令更新本地仓库:
+git pull
+
+++Verified
+
在 GitHub 的 commit 历史中看到的 “Verified” 标记,表示该提交是经过 签名验证(signed commit) 的,也就是 GitHub 能确认这个 commit 的确是由声明的提交者(你)签名并发布的。可以通过GPG或者SSH配置:
+sudo pacman -S gnupg //安装 GPG
+gpg --full-generate-key //生成 GPG 密钥
+gpg --list-secret-keys --keyid-format=long //查看你生成的密钥 ID
+git config --global user.signingkey ABCDEF1234567890 //让 Git 使用该密钥签名
+git config --global commit.gpgsign true //启用自动签名所有提交
+gpg --armor --export ABCDEF1234567890 //导出公钥并添加到 GitHub
+
+然后前往GitHub → Settings → SSH and GPG keys → New GPG key粘贴并保存。
可以用你平时登录 GitHub 的同一个 SSH 密钥:
+git config --global gpg.format ssh //让 Git 使用 SSH 格式签名
+git config --global user.signingkey ~/.ssh/Github.pub //指定使用的 SSH 公钥
+git config --global commit.gpgsign true //表示自动签名所有提交
+
+然后前往Settings → SSH and GPG keys → New SSH key → Signing key粘贴并保存。
首先创建这个文件:
+mkdir -p ~/.ssh
+nano ~/.ssh/allowed_signers
+
+写入你的 test@mail.com ssh-ed25519 AAAABBBBBBBBBBBBBBBBxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx并保存。
+随后配置Git信任该文件:
git config --global gpg.ssh.allowedSignersFile ~/.ssh/allowed_signers
+
+随后使用git log --show-signature即可查看本地log中的
Good "git" signature for test@mail.com with ED25519 key SHA256:ssh-ed25519 AAAABBBBBBBBBBBBBBBBBBBBB
+
+分支是用来将特性开发绝缘开来的。比如你在本地的test分支新增了一个功能,想要合并到主分支中。
+创建一个叫做“test”的分支,并切换过去:
+git checkout -b test
+
+新增某些功能后切换回主分支:
+git checkout master
+
+在主分支上执行合并操作,将 test 分支的改动合并到主分支:
+git merge test
+
+推送完成后可以把新建的分支删掉:
+git branch -d test
+
+- 列出所有本地分支
+git branch
+
+- 列出所有远程分支
+git branch -r
+
+- 列出所有本地分支和远程分支
+git branch -a
+
+- 列出所有本地分支,并展示没有分支最后一次提交的信息
+git branch -v
+
+- 列出所有本地分支,并展示没有分支最后一次提交的信息和远程分支的追踪情况
+git branch -vv
+
+- 列出所有已经合并到当前分支的分支
+git branch --merged
+
+- 列出所有还没有合并到当前分支的分支
+git branch --no-merged
+
+- 新建一个分支,但依然停留在当前分支
+git branch [branch-name]
+
+- 新建一个分支,并切换到该分支
+git checkout -b [branch]
+
+- 新建一个与远程分支同名的分支,并切换到该分支
+git checkout --track [branch-name]
+
+- 新建一个分支,指向指定commit
+git branch [branch] [commit]
+
+- 新建一个分支,与指定的远程分支建立追踪关系
+git branch --track [branch] [remote-branch]
+
+- 切换到指定分支,并更新工作区
+git checkout [branch-name]
+
+- 切换到上一个分支
+git checkout -
+
+- 建立追踪关系,在现有分支与指定的远程分支之间
+git branch --set-upstream-to=[remote-branch]
+git branch --set-upstream [branch] [remote-branch] - 已被弃用
+
+- 合并指定分支到当前分支
+git merge [branch]
+
+- 中断此次合并(你可能不想处理冲突)
+git merge --abort
+
+- 选择一个commit,合并进当前分支
+git cherry-pick [commit]
+
+- 删除分支
+git branch -d [branch-name]
+
+#新增远程分支 远程分支需先在本地创建,再进行推送
+git push origin [branch-name]
+
+- 删除远程分支
+git push origin --delete [branch-name]
+git branch -dr [remote/branch]
+
+Git 的 tag 功能主要用于给仓库历史中的某个特定提交打上“标签”,通常用于标记版本发布点(例如 v1.0、v2.0 等),以便于后续的版本定位、回溯和发布管理。
Git 提供两种类型的标签:
+附注标签(Annotated Tag)会创建成一个完整的 Git 对象,存储打标签者的名字、邮箱、日期和标签说明,还可采用 GPG 进行签名。推荐用于正式发布,因为包含更多元数据和安全信息。
+轻量标签(Lightweight Tag)实际上只是对某个提交的引用,不保存额外信息,类似一个固定的分支。适用于临时标记或非正式用途。
+使用 -a 参数表示“annotated”,并用 -m 提供标签说明。例如,给当前提交创建一个名为 v1.0 的附注标签:
+git tag -a v1.0 -m "发布版本 v1.0"
+
+这会在 Git 数据库中生成一个完整的标签对象,可通过 git show v1.0 查看标签信息和对应的提交详情。
+如果需要给旧提交贴标签,可以在命令末尾指定提交的 SHA 值(部分 SHA 也可):
+git tag -a v1.0 <commit-sha> -m "发布版本 v1.0"
+
+直接指定标签名即可,不加任何参数:
+git tag v1.0-light
+
+轻量标签仅仅是一个提交引用,因此查看时不会显示附加信息。
+git tag
+
+git tag -l "v1.*"
+
+这样便于管理和筛选大量标签。
+git show v1.0
+
+这会显示标签对象的元数据以及对应的提交记录。
+默认情况下,git push 不会将本地标签推送到远程仓库。推送标签有两种方式:
git push origin v1.0
+
+git push origin --tags
+
+git tag -d v1.0
+
+git push origin --delete v1.0
+
+如果你想了解本地仓库的历史记录,最简单的命令就是使用:
+git log
+
+git log --author=bob
+
+git log --pretty=oneline
+
+git log --name-status
+
+比如你修改了项目中的fs/proc/base.c,然后
git add fs/proc/base.c
+git commit -m "fix:base"
+git format-patch origin/16.0
+
+即可在目录下生成补丁0001-fix-base.patch.
有时候手滑或者不想使用一个commit说明,可以用以下命令撤销上一个 commit:
+git reset --soft HEAD~1
+
+这个命令会撤销上一个 commit,但保留文件修改(代码仍然在工作区)。适用于 想要重新提交(amend)或调整 commit 的情况。
+如果你想彻底删除更改(不保留代码修改),可以使用:
+git reset --hard HEAD~1
+
+++注意:--hard 会清除未提交的更改,无法恢复。
+
.git 目录中主要文件和子目录的结构及其作用.git 目录结构概览.git/
+├── HEAD
+├── config
+├── description
+├── hooks/
+├── index
+├── info/
+│ └── exclude
+├── logs/
+│ ├── HEAD
+│ └── refs/
+├── objects/
+│ ├── info/
+│ └── pack/
+├── refs/
+│ ├── heads/
+│ ├── remotes/
+│ └── tags/
+
+HEAD:指向当前检出的分支或提交。例如,ref: refs/heads/main 表示当前位于 main 分支。
config:仓库级别的配置文件,包含用户名、邮箱、远程仓库等信息.
+description:用于描述仓库,仅供 GitWeb 等工具使用。
+hooks/:存放 Git 钩子脚本的目录,可用于在特定操作前后执行自定义脚本,如 pre-commit、post-merge 等.
index:暂存区(staging area)的索引文件,记录了即将提交的文件信息。
+info/:包含辅助信息,如 exclude 文件用于定义仓库级别的忽略规则。
logs/:记录了引用(如分支、标签)的更新历史,有助于追踪操作记录。
+objects/:存储 Git 的所有对象,包括:
+refs/:存储所有引用,包括:
+<type>[可选的 scope]: <简短描述>
+
+type 表示提交类型,如:feat(新功能)、fix(修复bug)等。 +scope 是可选的,用于指出变更影响的模块或范围。 +简短描述 用于概述本次提交的核心内容,通常使用祈使语气。
+Body(正文) +用于详细说明变更的动机、方法以及可能的影响,建议每行不超过 72 个字符。
+Footer(脚注) +可选部分,用来引用相关 issue、任务或说明破坏性变更(例如:BREAKING CHANGE: ...)。例如:
+Fixes #123
+
+这可以在提交后自动关闭相关问题。
+- feat:新功能的添加
+ 示例:feat(user): 添加用户注册功能
+
+- fix:修复 Bug
+ 示例:fix(parser): 修复解析错误导致程序崩溃
+
+- docs:文档相关的修改
+ 示例:docs(readme): 更新使用说明
+
+- style:代码格式、排版等不影响代码逻辑的调整
+ 示例:style: 优化代码缩进和空格
+
+- refactor:代码重构,不涉及新功能或 Bug 修复
+ 示例:refactor: 优化数据处理逻辑
+
+- perf:性能优化
+ 示例:perf: 提升数据查询速度
+
+- test:添加或修改测试代码
+ 示例:test: 补充用户登录单元测试
+
+- build:构建相关的变更,如依赖管理、构建脚本等
+ 示例:build: 更新 webpack 配置
+
+- ci:持续集成相关的修改
+ 示例:ci: 调整 GitHub Actions 配置
+
+- chore:其他杂项维护,不涉及源代码或测试文件的修改
+ 示例:chore: 更新项目依赖
+
+- revert:回滚到上一个版本的提交
+ 示例:revert: 撤销上次提交
+
+Done.
+ +前言 PGP/GPG 的核心功能——公钥加密、数字签名、信任管理广泛用于各个行业,本文简单说明了其使用方法。
+PGP(Pretty Good Privacy)
+GPG(GNU Privacy Guard,又称 GnuPG)
+| 时间 | 事件 |
|---|---|
| 1991 年 | Phil Zimmermann 发布 PGP 1.0,标志个人加密进入大众市场 |
| 1994 年 | PGP 因出口管制遭到美国政府调查,后续改版加密算法合规化 |
| 1997 年 | GNU 推出 GnuPG,目标创建一个开源、自由的 OpenPGP 实现 |
| 2001 年 | OpenPGP 正式成为 IETF 标准(RFC 2440) |
| 2006 年 | GnuPG 2.0 发布,引入多子系统(gpg-agent、dirmngr 等) |
| 2014 年 | OpenPGP 更新为 RFC 4880bis,GnuPG 不断改进对新算法的支持 |
| 应用领域 | 描述 |
|---|---|
| 1. 电子邮件加密与签名 | - PGP/MIME:通过邮件客户端(如 Thunderbird + Enigmail)对正文和附件加密,并用私钥签名。 - PGP inline:将加密/签名内容以纯文本形式嵌入邮件,兼容性更强。 |
| 2. 文件与目录的加密签名 | - 单文件加密/解密:gpg --encrypt --recipient Alice file.txtgpg --decrypt file.txt.gpg- 归档目录加密:使用 tar 打包后再加密。- 签名校验: gpg --detach-sign --armor release.tar.gzgpg --verify release.tar.gz.asc release.tar.gz |
| 3. 软件包与系统镜像签名 | - Linux 包管理签名:APT、pacman-key 等验证来源可信性。 - 容器镜像签名:结合 TUF/Notary 使用 GPG 保护 Docker 镜像完整性。 |
| 4. SSH 公钥管理与登录 | - 将 GPG 子密钥作为 SSH 密钥使用:echo "enable-ssh-support" >> ~/.gnupg/gpg-agent.confgpgconf --reload gpg-agentssh-add -L- 好处:私钥集中管理、PIN保护、跨平台一致。 |
| 5. 自动化脚本与 CI/CD 环境 | - 用 GPG 自动签名构建产物,供用户验证。 - 将签名集成进发布脚本(如 release.sh),自动生成 .sig 并上传。 |
| 6. 文档与 PDF 数字签名 | - 利用 gpgsm 或 OpenPGP.js 对 PDF、Office 文档签名,保障法律或审计合规性。 |
| 7. 密码管理与“密码库” | - pass:每个密码为一个 GPG 加密文件,支持 Git 同步和版本控制。 - git-crypt:自动加密 Git 仓库中的敏感文件,仅授权者可解密。 |
| 8. 安全聊天与即时通讯 | - 将 OTR 会话密钥托管在 GPG 中(如 mcabber + OTR),实现端到端加密。 |
| 9. 时间戳与不可篡改日志 | - 结合 GPG 签名与时间戳协议(如 RFC 3161)验证文件/日志未被篡改。 |
| 10. 去中心化信任与身份管理 | - 使用 Web of Trust 模型构建可信身份网络,用于开源社区签名、Key Signing Party、LDAP 交换等。 |
paru -S gnupg
+
+使用如下命令:
+gpg --full-generate-key
+
+生成流程:
+gpg (GnuPG) 2.4.7; Copyright (C) 2024 g10 Code GmbH
+This is free software: you are free to change and redistribute it.
+There is NO WARRANTY, to the extent permitted by law.
+
+Please select what kind of key you want:
+ (1) RSA and RSA
+ (2) DSA and Elgamal
+ (3) DSA (sign only)
+ (4) RSA (sign only)
+ (9) ECC (sign and encrypt) *default*
+ (10) ECC (sign only)
+ (14) Existing key from card
+Your selection? 9 ## 默认选择ECC算法
+Please select which elliptic curve you want:
+ (1) Curve 25519 *default*
+ (4) NIST P-384
+ (6) Brainpool P-256
+Your selection? 1 ## 默认选择标准椭圆曲线
+Please specify how long the key should be valid.
+ 0 = key does not expire
+ <n> = key expires in n days
+ <n>w = key expires in n weeks
+ <n>m = key expires in n months
+ <n>y = key expires in n years
+Key is valid for? (0) 1y ## 默认有效期为一年
+Key expires at 2026年06月17日 星期三 13时06分27秒 CST
+Is this correct? (y/N) y
+
+GnuPG needs to construct a user ID to identify your key.
+
+## 输入名字与邮箱,comment可省略
+
+Real name: xxx
+Email address: xxx@gmail.com
+Comment:
+You selected this USER-ID:
+ "xxx <xxx@gmail.com>"
+
+Change (N)ame, (C)omment, (E)mail or (O)kay/(Q)uit?
+Change (N)ame, (C)omment, (E)mail or (O)kay/(Q)uit? O
+We need to generate a lot of random bytes. It is a good idea to perform
+some other action (type on the keyboard, move the mouse, utilize the
+disks) during the prime generation; this gives the random number
+generator a better chance to gain enough entropy.
+We need to generate a lot of random bytes. It is a good idea to perform
+some other action (type on the keyboard, move the mouse, utilize the
+disks) during the prime generation; this gives the random number
+generator a better chance to gain enough entropy.
+
+gpg --list-secret-keys --keyid-format long
+
+其中sec ed25519/xxxxxxxxx 2025-06-17 [SC] [expires: 2026-06-17]的xxxxxxxxx即为公钥ID。
例如上传你的 key:
+gpg --send-keys <你的Long‑Key‑ID>
+
+默认为你的 gpg.conf 中配置的 keyserver,也可以显式指定:
+gpg --keyserver hkps://keys.openpgp.org --send-keys <Key‑ID>
+
+也可以使用如下命令导出公钥为可读 ASCII 格式,类似ssh-keys,随后即可发布在个人博客上等等。
+gpg --armor --export <Key‑ID> > mypubkey.asc
+
+如果怀疑密钥被泄露或被中间人替换,立即发布“撤销证书”(revocation certificate)并上传到 keyserver。
+gpg --gen-revoke <KeyID> > revoke.asc
+
+上传撤销证书后,所有人都能知道该公钥已不再可信。
+Done.
+ +前言 在从前的机械硬盘时代,由于硬盘空间小,且没有时常清理垃圾文件,常常导致硬盘空间严重不足;特别是在以 Windows 平台为代表的 C/D盘 体系下。那么,我们常说的垃圾清理,释放硬盘空间,到底是在清理什么?哪些文件可以被清理?
+通常指的是清理计算机硬盘上的不必要或临时文件,以释放硬盘空间。这些文件包括:
++注意,清理缓存文件可能意味着加载速度变慢或需要重新下载,耗费流量,视情况而清理。
+
++特别是C盘上的log文件,因为它们记录了系统和应用程序的运行情况,可能会变得相当庞大。因此,定期清理C盘中的log文件是维护系统性能和释放磁盘空间的重要步骤之一。
+
++例如PS加载的工作文件,放C盘的话会占用大量空间。
+
++还记得删除牛马软件时的挽留选项吗?里面往往藏着“保存个人配置”。
+
++这里再次点名微信,同样一个文件能保存好几次,且不给出具体的存放路径,怪不得动辄十几个G,尾大不掉,真的离谱!
+
++注意,尽管清空回收站会立即释放硬盘空间,但实际上删除的文件并不会立即被擦除,而是被标记为可以被覆写的空间。在某些情况下,专业的数据恢复软件可能仍然可以找回部分被删除的文件。因此,如果希望永久删除文件而不被恢复,需要使用专门的文件删除工具,来覆盖文件内容以确保无法恢复。
+
++例如安卓上的安装包(APK文件)和下载安装后的EXE文件。
+
需要注意的是,往往有许多牛马软件安装目录和文件目录不规范,或者是在安装时没有设定好,会产生大量垃圾文件;这时就需要垃圾清理工具或者手动遍历文件夹(注意隐藏文件夹)。
+缓存清理:
+sudo pacman -Sc: 清理包缓存,删除已安装的但不再需要的软件包。sudo pacman -Scc: 进一步清理所有包文件,包括已下载的包。系统日志:
+/var/log 目录下包含系统日志文件。你可以删除较旧的日志文件,或者使用日志轮换工具,如 logrotate。临时文件:
+/tmp 目录下包含临时文件。你可以通过 sudo rm -rf /tmp/* 清理它们。缓存文件:
+~/.cache 目录下存储缓存文件。你可以检查该目录并删除不再需要的文件。AUR 缓存:
+yay)会在 ~/.cache/yay 目录下存储构建和下载的软件包。你可以清理这些文件。旧内核:
+uname -r 查看当前内核版本,然后使用 sudo pacman -Rns linux-older-kernel 删除不需要的版本。不再使用的配置文件:
+~/.config,并删除不再需要的配置文件。Docker日志文件:
+使用 docker ps -a 命令查找你感兴趣的容器的 ID。
docker ps -a
+
+进入容器的日志目录,路径类似于 /var/lib/docker/containers/<container-id>/。
cd /var/lib/docker/containers/<container-id>/
+
+使用命令清理或删除日志文件。你可以删除所有日志文件,或者只删除特定的日志文件。
+# 删除所有日志文件
+rm *.log
+
+# 删除特定日志文件(例如 stdout 和 stderr)
+rm *-json.log
+
+你可以定期备份 Arch Linux 安装的软件列表,以便在需要时轻松还原。
+pacman -Qqe > package-list.txt
+
+这将列出所有已安装的软件包,并将其保存到文件 package-list.txt 中。在还原系统时,你可以使用以下命令:
sudo pacman -S --needed - < package-list.txt
+
+垃圾文件的产生总是无可避免,这是因为随着使用时间的流逝,系统的熵值也在增大;生命以负熵为食,同样的为系统清理垃圾也是逆熵的一部分。在你的生命中会有许多电子设备,但它们往往只有你一任主人,请善待它们!
+ +前言 LazyVim 是一个基于 Neovim 的现代化配置框架,易于定制和扩展,这里对其介绍并说明使用方法。
+++Vim 是从早期的 vi 编辑器发展而来的增强版,其名称代表“Vi IMproved”。由荷兰程序员 Bram Moolenaar 于 1991 年首次发布。Vim 是开源软件,支持多种操作系统,包括 Unix、Linux、Windows 和 macOS 等。
+
++LazyVim 是一个基于 Neovim 的现代化配置框架,旨在简化 Neovim 的配置过程。它通过集成的 lazy.nvim 插件管理器,提供了一种易于定制和扩展配置的方式,结合了从头开始配置的灵活性和预配置设置的便利性 。
+
++LazyVim 是在Neovim的基础上进行配置,Neovim又继承了vim的操作模式,对vim不熟悉的同学可以看这里或者本文末尾的 Vim 速查表.
+
首先安装neovim,在arch linux上是:
+paru -S neovim
+
+在Ubuntu上是
+sudo add-apt-repository ppa:neovim-ppa/unstable
+sudo apt update
+sudo apt install -y \ neovim git curl unzip build-essential ripgrep fd-find
+
+备份现有配置:
+mv ~/.config/nvim ~/.config/nvim.bak
+mv ~/.local/share/nvim ~/.local/share/nvim.bak
+
+克隆 LazyVim Starter 模板:
+git clone https://github.com/LazyVim/starter ~/.config/nvim
+
+启动 Neovim:
+nvim
+
+首次启动时,LazyVim 会自动安装并配置所需的插件。
+LazyVim 的配置目录通常位于~/.config/nvim/中:
~/.config/nvim
+❯ tree
+.
+├── init.lua
+├── lazy-lock.json
+├── lazyvim.json
+├── LICENSE
+├── lua
+│ ├── config
+│ │ ├── autocmds.lua
+│ │ ├── keymaps.lua
+│ │ ├── lazy.lua
+│ │ └── options.lua
+│ └── plugins
+│ ├── example.lua
+│ └── mp.lua
+├── README.md
+└── stylua.toml
+
+4 directories, 12 files
+
+另外在~/.local/share/nvim/lazy/LazyVim/lua/lazyvim/plugins/目录下看到的文件结构,是 LazyVim 为其核心插件和扩展插件提供的模块化配置体系。这些配置文件并不直接出现在~/.config/nvim/lua/plugins/目录中,是因为 LazyVim 采用了模块化和懒加载的设计理念,将核心插件和配置封装在其自身的代码库中。
init.lua:主配置文件,负责加载 lua/config/lazy.lua,从而引导整个 LazyVim 的初始化过程。
lazy-lock.json:由 lazy.nvim 插件管理器生成的锁定文件,记录了已安装插件的精确版本,确保插件的一致性。
lazyvim.json:用于记录通过 :LazyExtras 命令启用的额外功能(Extras),便于在不同设备间同步配置。
LICENSE 和 README.md:分别为许可协议和项目说明文档。
stylua.toml:stylua 的配置文件,用于格式化 Lua 代码。
lua/config/:包含 Neovim 的基础配置文件,如自动命令(autocmds.lua)、快捷键(keymaps.lua)、插件管理(lazy.lua)和编辑器选项(options.lua)。这些文件会被 LazyVim 自动加载,无需手动引入。
lua/plugins/:用于添加或修改插件配置的目录。您可以在此目录中添加新的 Lua 文件,以引入其他插件或更改现有插件的设置。
+
在 LazyVim 中,插件被分类为已加载(Loaded)和未加载(Not Loaded)。
+blink.cmp:一个高性能、开箱即用的自动补全引擎,旨在替代 nvim-cmp,提供更快的性能和更少的配置需求。
bufferline.nvim:用于在顶部显示缓冲区列表的插件,提供类似于浏览器标签页的界面。
+friendly-snippets:一个包含多种语言代码片段的集合,可与多个片段引擎(如 luasnip)配合使用。
gitsigns.nvim:在编辑器中显示 Git 更改标记(如添加、修改、删除)的插件,增强版本控制的可视化。
+lazy.nvim:LazyVim 的插件管理器,支持懒加载和依赖管理,提升启动速度和性能。
+lualine.nvim:一个高度可定制的状态栏插件,支持多种主题和组件。
+mason-lspconfig.nvim & mason.nvim:用于自动安装和配置 LSP(语言服务器协议)服务器的插件组合,简化开发环境的设置。
+mini.ai、mini.pairs:mini.nvim 插件集合的一部分,分别用于增强文本对象操作和自动括号配对功能。
noice.nvim:改进 Neovim 消息和命令行界面的插件,提供更丰富的 UI 体验。
+nui.nvim:一个用于构建 Neovim 用户界面的 Lua 库,被多个插件作为依赖使用。
+nvim-lint:一个异步代码检查器,支持多种语言的语法和风格检查。
+nvim-lspconfig:提供预配置的 LSP 客户端设置,简化语言服务器的集成。
+nvim-treesitter、nvim-treesitter-textobjects、nvim-ts-autotag:基于 Tree-sitter 的语法高亮和代码结构分析插件,增强代码编辑体验。
+persistence.nvim:自动保存和恢复会话的插件,方便在不同项目之间切换。
+snacks.nvim:提供快速导航和编辑功能的插件,提升编辑效率。
+todo-comments.nvim:高亮和管理代码中的 TODO、FIXME 等注释的插件,方便任务跟踪。
+tokyonight.nvim:一个流行的 Neovim 主题,提供多种配色方案。
+trouble.nvim:一个用于显示诊断信息(如 LSP 错误、警告)的插件,提供统一的界面。
+ts-comments.nvim:基于 Tree-sitter 的注释插件,支持多语言的智能注释功能。
+which-key.nvim:在按下快捷键时弹出可用键位提示的插件,帮助记忆和发现快捷键。
+catppuccin:一个柔和的 Neovim 主题,提供多种风格的配色方案。
+conform.nvim:一个用于代码格式化的插件,支持多种语言的格式化工具。
+grug-far.nvim:一个快速的全局查找和替换插件,提供直观的界面和操作。
+lazydev.nvim:用于 LazyVim 插件开发的辅助工具,简化开发流程。
+markdown-preview.nvim:在浏览器中实时预览 Markdown 文件的插件,提升写作体验。
+plenary.nvim:一个 Lua 函数库,提供多种实用功能,被许多插件作为依赖使用。
+添加插件:在 lua/plugins/ 目录下创建一个新的 Lua 文件,返回插件的配置表。
+修改快捷键:编辑 lua/config/keymaps.lua 文件,添加或修改快捷键映射。
+调整选项:编辑 lua/config/options.lua 文件,设置 Neovim 的行为选项。
+LazyVim 默认使用<space> 作为 <leader>,\ 作为<localleader>,并通过 which-key.nvim 插件动态展示所有以<space>开头的可用映射,极大降低了记忆成本。
- 在窗口间切换:Ctrl +h / Ctrl +j / Ctrl +k / Ctrl +l
+- 调整当前窗口尺寸:Ctrl + ↑ / Ctrl + ↓ / Ctrl + ← / Ctrl + →
+
+- 切换到上一个/下一个缓冲区:Shift +h / Shift +l
+- 切换“另一个”缓冲区:Space + b + b
+- 关闭当前缓冲区:Space + b + d
+- 只保留当前缓冲区:Space + b + o
+
+- 新建文件:Space + f + n
+- 打开文件(普通命令):输入 :e <文件名> 回车
+- 在项目根目录查找文件:Space + Space
+- 在项目根目录查找文件(另一路径):Space + f + f
+- 在当前工作目录查找文件:Space + f + F
+- 查找 Git 管理的文件:Space + f + g
+- 列出最近打开的文件:Space + f + r
+- 列出所有缓冲区:Space + ,
+- 全局全文搜索:Space + /
+
+- 向下分割:Space + -
+- 向右分割:Space + |
+- 关闭当前窗口:Space + w + d
+- 窗口最大化/恢复:Space + w + m 或 Space + u + Z
+- 打开根目录终端:Space + f + t
+- 打开当前目录终端:Space + f + T
+- 切换(隐藏/显示)终端:Ctrl + /
+
+- 跳转到定义:g + d
+- 查找引用:g + r
+- 跳转到实现:g + I
+- 跳转到声明:g + D
+- 查看文档悬停:K
+- 插入模式签名帮助:Ctrl + k
+- 代码操作:Space + c + a
+- 重命名:Space + c + r
+- 运行 CodeLens:Space + c + c
+- 显示行诊断:Space + c + d
+
+- 查看状态:Space + g + s
+- 查看差异:Space + g + d
+- 查看行级 Blame:Space + g + b
+- 在浏览器打开当前文件:Space + g + B
+- Git Stash(snacks.nvim):Space + g + S
+
+- 打开 Location List:Space + x + l
+- 打开 Quickfix List:Space + x + q
+- 在 Quickfix 跳转:[ q / ] q
+
+在~/config/nvim/lua/plugins/下新建一个mp.lua,写入如下配置:
return {
+ {
+ "iamcco/markdown-preview.nvim",
+ cmd = { "MarkdownPreviewToggle", "MarkdownPreview", "MarkdownPreviewStop" },
+ ft = { "markdown" },
+ build = ':call mkdp#util#install()'
+ }
+}
+
+随后即可在 Neovim 中打开一个 Markdown 文件,执行以下命令启动预览:
+:MarkdownPreview
+
+:set fileencoding?:set fileformat=unix| 快捷键 | 功能 |
|---|---|
gd | 跳转到定义(Go to Definition) |
gr | 查找引用(Go to References) |
K | 显示悬浮文档(Hover) |
<leader>rn | 重命名(Rename) |
<leader>ca | Code Action(修复) |
gl | 显示诊断信息(Diagnostic) |
[d / ]d | 上/下一个诊断问题 |
++编辑器的基本素养
+
外观
编辑器
Code
字符处理
终端
文件操作
其他功能
++翻译自
+https://vimsheet.com/
我整理了一份我每天使用的 Vim 基本命令列表,并提供了一些配置建议,使 Vim 更加实用。因为没有配置的 Vim 使用起来会比较痛苦。
+h j k l:左、下、上、右移动w / b:下一个/上一个单词W / B:下一个/上一个以空格分隔的单词e / ge:下一个/上一个单词的结尾0 / $:行首/行尾^:行首第一个非空白字符(等同于 0w)i / a:在光标处/之后进入插入模式I / A:在行首/行尾进入插入模式o / O:在当前行下方/上方插入空行Esc 或 Ctrl+[:退出插入模式d:删除dd:删除整行c:删除并进入插入模式cc:删除整行并进入插入模式d:从光标处删除到移动目标c:从光标处删除到移动目标,并进入插入模式y:从光标处复制到移动目标>:缩进一级<:取消缩进一级d$ 删除从光标到行尾的内容v:进入可视模式V:进入行可视模式Ctrl+v:进入块可视模式Esc 或 Ctrl+[:退出可视模式yy:复制整行p:在光标后粘贴P:在光标前粘贴dd:剪切整行x:删除当前字符X:删除前一个字符d / c 会将删除的内容复制到剪贴板:w:保存文件但不退出:wq:保存并退出:q:退出(如果有修改会失败):q!:强制退出并放弃修改/pattern:搜索 pattern?pattern:向上搜索 patternn:重复上一次搜索(同方向)N:重复上一次搜索(反方向):%s/old/new/g:全文件替换 old 为 new:%s/old/new/gc:全文件替换 old 为 new,并逐个确认u:撤销Ctrl+r:重做Ctrl+d:向下移动半页Ctrl+u:向上移动半页}:跳转到下一个段落(空行){:跳转到上一个段落(空行)gg:跳转到文件顶部G:跳转到文件底部:[num]:跳转到指定行号Ctrl+e / Ctrl+y:向下/向上滚动一行f [char]:向前移动到指定字符F [char]:向后移动到指定字符t [char]:向前移动到指定字符之前T [char]:向后移动到指定字符之前; / ,:重复上一次字符搜索(正向/反向)J:将下一行合并到当前行r [char]:用指定字符替换当前字符(不进入插入模式)O:移动到块的另一个角o:移动到标记区域的另一端:e filename:编辑文件:tabe:打开新标签页gt:切换到下一个标签页gT:切换到上一个标签页:vsp:垂直分割窗口Ctrl+ws:水平分割窗口Ctrl+wv:垂直分割窗口Ctrl+ww:在窗口间切换Ctrl+wq:关闭当前窗口m{a-z}:在光标位置设置标记 {a-z}'{a-z}:跳转到设置标记的行首'':返回上一个跳转位置def (arg1, arg2, arg3),光标在括号内di(:删除括号内的内容,即“删除最近括号内的内容”T(dt) 来实现相同的功能.:重复上一次命令Ctrl+r 0:插入最近复制的文本gv:重新选择上一次选中的文本块%:在匹配的 () 或 {} 之间跳转如果你希望将此速查表保存为 PDF 或打印出来,可以使用 Markdown 编辑器(如 Typora)或在线工具(如 Dillinger)进行导出。
+此外,Vim 的默认配置可能不够友好,建议你参考以下资源进行配置优化:
+这些插件可以显著提升 Vim 的功能,使其更接近一个完整的 IDE。
+🔗
+ +Done.
+ +前言 本文为 Markdown 教程,内容涵盖 Markdown 的历史、作用、基本语法和显示效果,可以在github将本文的源码拷贝供大家参考和学习。
+Markdown 是一种轻量级标记语言,最初由约翰·格鲁伯(John Gruber)在 2004 年创建,其设计目标在于简洁易读,同时能够快速转换为 HTML。Markdown 被广泛用于撰写文档、博客、论坛帖子以及 README 文档,其直观的语法和高度可读性受到开发者和写作者的一致好评。
+历史沿革:
+2004 年左右,随着互联网内容量的增加以及对纯文本格式的需求不断上升,人们开始寻找一种既能保留纯文本的可读性,又能方便地生成格式化内容(如 HTML)的解决方案。Markdown 应运而生。经过十多年的发展,Markdown 已衍生出多个方言(例如 GitHub Flavored Markdown、CommonMark 等),并被各种编辑器、静态博客生成器(如 Zola、Jekyll、Hugo 等)以及内容管理系统所支持。
主要作用:
+下面详细介绍 Markdown 常用的语法,并演示其在渲染后显示的效果。
+使用井号 # 来表示标题,井号的数量表示标题级别(1~6级)。
# 这是一级标题
+## 这是二级标题
+### 这是三级标题
+#### 这是四级标题
+##### 这是五级标题
+###### 这是六级标题
+
+渲染效果:
+* 或下划线 _。** 或下划线 __。***。*这是斜体*
+_这也是斜体_
+
+**这是加粗**
+__这也是加粗__
+
+***这是斜体加粗***
+
+渲染效果:
+这是斜体
+这也是斜体
这是加粗
+这也是加粗
这是斜体加粗
+使用 -、* 或 + 表示无序列表项。
- 项目 1
+- 项目 2
+ - 子项目 2.1
+ - 子项目 2.2
+- 项目 3
+
+渲染效果:
+使用数字后面跟点号来表示有序列表:
+1. 第一项
+2. 第二项
+3. 第三项
+
+渲染效果:
+格式:链接文字。
+[GitHub](https://github.com "GitHub 官网")
+
+渲染效果:
+GitHub
格式:。

+
+渲染效果:
+使用反引号 ` 来表示行内代码。
使用 `printf()` 函数输出内容。
+
+渲染效果:
+使用 printf() 函数输出内容。
代码块使用三个反引号(```)包裹,也可以指定语言以便进行语法高亮。
+```python
+def hello():
+ print("Hello, World!")
+```
+
+++注意:上述代码块中第一行的三个反引号后面紧跟着语言名称(如
+python),结束时用相同的三个反引号结束。
渲染效果(依赖编辑器或平台的语法高亮支持):
+def hello():
+ print("Hello, World!")
+
+使用 > 来表示引用(Blockquote)。
> 这是引用的内容,可以用于引用名言或文章片段。
+>
+> 多行引用时,每行前面都加上 `>`。
+
+渲染效果:
+++这是引用的内容,可以用于引用名言或文章片段。
+多行引用时,每行前面都加上
+>。
使用三个或更多的横线 ---、星号 *** 或下划线 ___ 来产生水平分割线。
---
+或者
+***
+或者
+___
+
+渲染效果:
+或者
+或者
+Markdown 表格可以使用管道符 | 和短横线 - 来创建。
| 表头1 | 表头2 | 表头3 |
+| :--- | :---: | ---: |
+| 左对齐 | 居中对齐 | 右对齐 |
+| 单元格内容 | 更多内容 | 数据 |
+
+渲染效果:
+| 表头1 | 表头2 | 表头3 |
|---|---|---|
| 左对齐 | 居中对齐 | 右对齐 |
| 单元格内容 | 更多内容 | 数据 |
++注:
+
+“:---” 表示左对齐;
+“:---:” 表示居中对齐;
+“---:” 表示右对齐。
不同平台可能支持额外的 Markdown 扩展语法,下面列举一些常见的扩展功能:
+某些 Markdown 方言支持脚注。脚注格式如下:
+这是一个带脚注的句子.[^1]
+
+[^1]: 这是脚注的内容。
+
+渲染效果:
+这是一个带脚注的句子.1
+这是脚注的内容。
+GitHub Flavored Markdown(GFM)支持任务列表,可以用于表示待办事项。
+- [x] 完成 Markdown 教程
+- [ ] 阅读更多文章
+- [ ] 分享教程
+
+渲染效果:
+空行与段落:
+Markdown 使用一个或多个空行来分隔不同的段落。如果要换行但不创建新段落,在行尾添加两个或更多空格后回车即可。
转义字符:
+如果想要显示 Markdown 特殊符号而不被解析,比如 *、#、\ 等,可以在前面加上反斜杠 \。
\*这不是斜体,而是普通的星号\*
+
+渲染效果:
+*这不是斜体,而是普通的星号*
原始文本展示:
+为了展示 Markdown 源码而不被渲染,请使用代码块(反引号包围)或适用平台支持的原始文本标签(例如 {% raw %} 与 {% endraw %})。
Done.
+ +前言 机械革命作为一款极高性价比的笔记本,其优惠的力度和问题不断的故障让玩家们爱恨交织;作者在其上安装 Linux 时遇到了键盘失灵的问题,为了避免更多人踩坑,故写本文。
+作者在一台锐龙平台的笔记本上安装 Debian 时,先在虚拟机中尝试安装,没有发现异常;随后在实体机安装时发现 liveCD 中键盘不可用,无法设置密码和主机名,在连接外接键盘后安装完成,却发现Fn快捷键仍然可用。
+根据机革一贯的“特性”,作者猜测是因为 BIOS 或者 ACPI 出现了故障,随后在翻阅论坛时发现是由于锐龙笔记本键盘中断描述与其他键盘不同:其为边缘敏 感、低电平有效的;而蛟龙16K机器键盘实际是边缘敏感、高电平有效(Edge ActiveHigh)。结合 linux 的特性,读取到边缘敏感、低电平有效的中断时,会认为 BIOS 有Bug,会直接当成边缘敏感、高电平有效进行处理。因此,键盘就没有了响应。
+既然是高低电平表述的错误,那么我们只需建立DSDT 表副本,将其修改,然后让它优先启动,从而让键盘配置正常;另外还存在 BIOS 修复,内核编译的方法,比较复杂,这里不做说明。
+首先建立一个DSDT文件夹:
+sudo su
+mkdir -p /home/dsdt
+
+随后将系统的DSDT表读取到里面,并安装acpica-tools:
+cat /sys/firmware/acpi/tables/DSDT > dsdt.dat
+apt install acpica-tools
+iasl -d dsdt.dat
+
+进入vim编辑DSDT表,没有vim的先安装一个:
+apt install vim
+vim dsdt.dsl
+
+搜索并替换 Device(PS2K) 下面的
+IRQ (Edge, ActiveLow, Shared, )
+为
+IRQ (Edge, ActiveHigh, Shared, )
+
+vim搜索的方法为在命令模式下按下“/”,键入搜索字符并回车即可,按“n”跳转到下一处,“N”跳转到前一处,按: wq保存:
+
+随后搜索DefinitionBlock,将其步进值增加一(十六进制),即更改
+DefinitionBlock ("", "DSDT", 2, "ALASKA", "A M I", 0x01072009)
+为
+DefinitionBlock ("", "DSDT", 2, "ALASKA", "A M I", 0x0107200A)
+
+关闭DSDT,并设置其优先启动
+iasl dsdt.dsl
+mkdir -p kernel/firmware/acpi
+cp dsdt.aml kernel/firmware/acpi/
+find kernel | cpio -H newc --create > acpi_override
+cp acpi_override /boot/acpi_override
+echo "GRUB_EARLY_INITRD_LINUX_CUSTOM=\"acpi_override\"" >>/etc/default/grub
+
+更新并重启:
+
+sudo grub-mkconfig -o /boot/grub/grub.cfg
+sudo grub-install /dev/sdX
+sudo grub-install --target=x86_64-efi --efi-directory=/boot/efi --bootloader-id=grub
+
+update-grub2
+reboot
+
+不出意外,重启后键盘即可使用,若系统不同将 apt 替换即可。
+对于Redmi 或 Lenovo刚发布的AMD R7 6800H机型:
+# 内核小于5.18的
+git clone https://github.com/HRex39/rtl8852be.git
+# 内核大于等于5.18的
+git clone https://github.com/HRex39/rtl8852be.git -b dev
+
+cd rtl8852be
+make -j8
+sudo make install
+sudo modprobe 8852be
+
+# 内核=5.15
+git clone https://github.com/HRex39/rtl8852be_bt.git -b 5.15
+# 内核=5.18
+git clone https://github.com/HRex39/rtl8852be_bt.git -b 5.18
+
+cd rtl8852be_bt
+make -j8
+sudo make install
+
+首先去amd官网下载最新的linux-amd驱动:
+https://www.amd.com/zh-hans/support/linux-drivers // 22.20 for Ubuntu 20.04.5 HWE
+
+修改Deepin为ubuntu
+sudo vim /etc/os-release // ID=Deepin => ID=ubuntu
+
+sudo apt install ./amdgpu-install_22.20.50200-1_all.deb
+
+sudo vim /etc/apt/sources.list.d/amdgpu.list // focal => bionic
+
+sudo apt update
+
+sudo amdgpu-install --no-dkms
+
+sudo apt install inxi clinfo
+
+安装成功以后,用inxi查看下:
+inxi -G
Graphics: Device-1: AMD Rembrandt driver: amdgpu v: kernel
+ Display: x11 server: X.Org 1.20.11 driver: amdgpu,ati unloaded: fbdev,modesetting,vesa
+ resolution: 1920x1080~60Hz
+ OpenGL: renderer: AMD YELLOW_CARP (LLVM 14.0.1 DRM 3.42 5.15.34-amd64-desktop)
+ v: 4.6 Mesa 22.1.0-devel
+
+最后还原最初的修改:
+sudo vim /etc/os-release // ID=ubuntu => ID=Deepin
+sudo apt purge amdgpu-install
+
+看下效果图:
+➜ ~ glxinfo -B
+name of display: :0
+display: :0 screen: 0
+direct rendering: Yes
+Extended renderer info (GLX_MESA_query_renderer):
+ Vendor: AMD (0x1002)
+ Device: AMD YELLOW_CARP (LLVM 14.0.1, DRM 3.42, 5.15.34-amd64-desktop) (0x1681)
+ Version: 22.1.0
+ Accelerated: yes
+ Video memory: 2048MB
+ Unified memory: no
+ Preferred profile: core (0x1)
+ Max core profile version: 4.6
+ Max compat profile version: 4.6
+ Max GLES1 profile version: 1.1
+ Max GLES[23] profile version: 3.2
+Memory info (GL_ATI_meminfo):
+ VBO free memory - total: 1388 MB, largest block: 1388 MB
+ VBO free aux. memory - total: 3047 MB, largest block: 3047 MB
+ Texture free memory - total: 1388 MB, largest block: 1388 MB
+ Texture free aux. memory - total: 3047 MB, largest block: 3047 MB
+ Renderbuffer free memory - total: 1388 MB, largest block: 1388 MB
+ Renderbuffer free aux. memory - total: 3047 MB, largest block: 3047 MB
+Memory info (GL_NVX_gpu_memory_info):
+ Dedicated video memory: 2048 MB
+ Total available memory: 5120 MB
+ Currently available dedicated video memory: 1388 MB
+OpenGL vendor string: AMD
+OpenGL renderer string: AMD YELLOW_CARP (LLVM 14.0.1, DRM 3.42, 5.15.34-amd64-desktop)
+OpenGL core profile version string: 4.6 (Core Profile) Mesa 22.1.0-devel
+OpenGL core profile shading language version string: 4.60
+OpenGL core profile context flags: (none)
+OpenGL core profile profile mask: core profile
+
+OpenGL version string: 4.6 (Compatibility Profile) Mesa 22.1.0-devel
+OpenGL shading language version string: 4.60
+OpenGL context flags: (none)
+OpenGL profile mask: compatibility profile
+
+OpenGL ES profile version string: OpenGL ES 3.2 Mesa 22.1.0-devel
+OpenGL ES profile shading language version string: OpenGL ES GLSL ES 3.20
+
+安装下面的三方电源管理工具 Boost Changer,选择 Performance策略即可
wget https://github.com/nbebaw/boostchanger/releases/download/v4.4.0/boostchanger_4.4.0_amd64.deb
+
+https://zhuanlan.zhihu.com/p/530643928
+https://github.com/HRex39/rtl8852be
+ + + +前言 本文旨在介绍开源以及开源许可证,这些许可证规定了使用、修改和分发开源软件的条件。通过了解不同类型的开源许可证及其特点,读者将能够更好地理解在开发和使用开源软件时的法律和道德责任。
+「开源」一词对应英文 Open Source,最初起源于软件开发领域,因此也称为「开放源代码」,对应的软件则称为开源软件(Open Source Software,简称 OSS)。除了我们熟知的开源软件以外,开源的表现形式还有很多,例如开源硬件(Open Source Hardware)、开放设计(Open Design)、开放文档(Open Document)等等。开源的目的是分享共享、加速创新,可以说开源已经成为一种超越软件生产界限的运动和工作方式。
+对于很多刚踏入软件这个行业的小伙伴来说,「开源」是个比较陌生的概念。但是随着经手项目逐渐增多,会发现很多项目,尤其是一些大型项目,经常会引用到别人一些优秀的开源代码,而这些优秀的开源代码通常都会在最开始简单地附上一段关于授权的声明或在项目根目录下提供完整的授权声明文件,比如:「The project is licensed under the Apache 2 license.」,诸如此类便是「开源许可证」。
+开源不等于免费,开源也不等于没有约束
+透明度和安全性 +开源软件的代码是公开的,任何人都可以检查和改进它。这使得潜在的安全漏洞更容易被发现和修复,提升了软件的安全性。
+促进创新 +开源允许开发者自由研究和修改代码,推动技术进步。例如,Linux、Python、TensorFlow 等开源项目极大地促进了计算机科学和人工智能的发展。
+降低成本 +企业和个人可以免费使用开源软件,而不需要支付高昂的许可证费用。例如,使用 Linux 服务器代替 Windows Server 可以减少 IT 成本。
+快速迭代和社区支持 +开源项目通常由全球开发者社区维护和改进,Bug 修复和新功能开发的速度比封闭源代码的软件更快。例如,开源浏览器 Firefox 就依赖社区贡献不断改进。
+避免供应商锁定 +开源软件允许用户自由选择和修改代码,而不是被某个公司的专有软件绑定,避免了供应商锁定的问题。例如,MySQL 和 PostgreSQL 等开源数据库是很多企业的首选,避免依赖单一厂商。
+开源软件,顾名思义是指能够免费且不受限制地使用、再开发、再发布的软件。但在狭义上,只有符合开放源代码促进会(Open Source Initiative)定义的软件才能被称为开源软件。这个定义提出了十个特征,必须全部符合才能认定为开源软件。
+这些特征包括:
+根据这些标准,一些看似自由使用的软件可能不符合开源软件的定义。例如,Elasticsearch原本使用Apache 2.0授权,是真正的开源软件。但面对云服务提供商如AWS等将其用于营利目的却不回馈改进的情况,Elasticsearch在2021年1月选择了SSPL(Server Side Public License,服务器端公共许可证)和Elastic License两种许可证并行;SSPL要求如果将程序的功能或修改后的版本作为服务提供给第三方,则必须免费公开提供服务源代码,这违背了开源软件的定义。另一方面,Elastic License要求不能向第三方提供主机或托管服务,也违反了开源软件的定义,因此也不算严格意义上的「开源」。
+开源许可证是软件许可证的一种特殊形式,用于规定开源软件的使用、修改、分享等相关事宜。它是一种格式合同,涉及版权、专利、商标等权利义务,自动生效。
+在美国,一些法院认为软件许可证是合同(contract),一些法院则认为是许可(license)。两者的区别在于,许可在传统上是由地产或物主作出的,目的在于允许他人使用自己的地块或物品。因此,它是单方向的,不构成完整的合同,而是作为合同的一个要素,用来和他人交换的条件。由于合同和许可之分在法律上有着重要的意义,它们的违约救济和版权侵权救济等方面有着不同的规定。
+与美国不同,大陆法系国家如中国普遍认为开源软件许可证构成合同,但这种合同是事先规定好的标准化格式合同,并且自动生效。
+开源许可证的种类繁多,据不完全统计,广义上的开源许可证超过200种,其中OSI批准的许可证有96个。这些许可证的内容各不相同,有些条款非常有意思,例如,啤酒软件许可证(Beerware License)规定,用户与作者聚会时可以请作者喝一杯啤酒;Jason Hunter 许可证规定,如果将该许可证下的代码用于商业目的,那么项目开发团队的所有成员都必须拥有 Jason Hunter 撰写的《Java Servlet编程》最新版。
+世界上的开源许可证(Open Source License)大概有上百种,而常见的开源协议大致有GPL、BSD、MIT、Mozilla、Apache和LGPL等。
+
+ ++
Apache License(Apache许可证),是Apache软件基金会发布的一个自由软件许可证。
+Apache Licence 是著名的非盈利开源组织 Apache 采用的协议。该协议和BSD类似,同样鼓励代码共享和最终原作者的著作权,同样允许源代码修改和再发布。但是也需要遵循以下条件:
+Apache Licence 也是对商业应用友好的许可。使用者也可以再需要的时候修改代码来满足并作为开源或商业产品发布/销售。
+使用这个协议的好处是:
+BSD 是"Berkeley Software Distribution"的缩写,意思是"伯克利软件发行版"。
+BSD开源协议:是一个给于使用者很大自由的协议。可以自由的使用,修改源代码,也可以将修改后的代码作为开源或者专有软件再发布。 当你发布使用了BSD协议的代码,或则以BSD协议代码为基础做二次开发自己的产品时,需要满足三个条件:
+如果再发布的产品中包含源代码,则在源代码中必须带有原来代码中的BSD协议。
+如果再发布的只是二进制类库/软件,则需要在类库/软件的文档和版权声明中包含原来代码中的BSD协议。
+不可以用开源代码的作者/机构名字和原来产品的名字做市场推广。
+BSD代码鼓励代码共享,但需要尊重代码作者的著作权。BSD由于允许使用者修改和重新发布代码,也允许使用或在BSD代码上开发商业软件发布和销售,因此是对商业集成很友好的协议。而很多的公司企业在选用开源产品的时候都首选BSD协议,因为可以完全控制这些第三方的代码,在必要的时候可以修改或者二次开发。
+GPL (GNU General Public License) :GNU通用公共许可协议。
+Linux 采用了 GPL。
+GPL 协议和 BSD, Apache Licence 等鼓励代码重用的许可很不一样。GPL 的出发点是代码的开源/免费使用和引用/修改/衍生代码的开源/免费使用,但不允许修改后和衍生的代码做为闭源的商业软件发布和销售。这也就是为什么我们能用免费的各种 linux,包括商业公司的 linux 和 linux 上各种各样的由个人,组织,以及商业软件公司开发的免费软件了。
+LGPL是GPL的一个为主要为类库使用设计的开源协议。和 GPL 要求任何使用/修改/衍生之GPL类库的的软件必须采用GPL协议不同。LGPL允许商业软件通过类库引用(link)方式使用LGPL类库而不需要开源商业软件的代码。这使得采用 LGPL 协议的开源代码可以被商业软件作为类库引用并发布和销售。
+但是如果修改 LGPL 协议的代码或者衍生,则所有修改的代码,涉及修改部分的额外代码和衍生的代码都必须采用 LGPL 协议。因此LGPL协议的开源代码很适合作为第三方类库被商业软件引用,但不适合希望以 LGPL 协议代码为基础,通过修改和衍生的方式做二次开发的商业软件采用。
+GPL/LGPL都保障原作者的知识产权,避免有人利用开源代码复制并开发类似的产品。
+MIT是和BSD一样宽范的许可协议,源自麻省理工学院(Massachusetts Institute of Technology, MIT),又称X11协议。作者只想保留版权,而无任何其他了限制。MIT与BSD 类似,但是比 BSD 协议更加宽松,是目前最少限制的协议。这个协议唯一的条件就是在修改后的代码或者发行包包含原作者的许可信息。适用商业软件。使用MIT的软件项目有:jquery、Node.js。
+MIT与BSD类似,但是比BSD协议更加宽松,是目前最少限制的协议。这个协议唯一的条件就是在修改后的代码或者发行包包含原作者的许可信息。适用商业软件。使用MIT的软件项目有:jquery、Node.js。
+MPL 协议允许免费重发布、免费修改,但要求修改后的代码版权归软件的发起者 。这种授权维护了商业软件的利益,它要求基于这种软件的修改无偿贡献版权给该软件。这样,围绕该软件的所有代码的版权都集中在发起开发人的手中。但MPL是允许修改,无偿使用得。MPL 软件对链接没有要求。
+EPL允许 Recipients 任意使用、复制、分发、传播、展示、修改以及改后闭源的二次商业发布。
+使用EPL协议,需要遵守以下规则:
+当一个 Contributors 将源码的整体或部分再次开源发布的时候,必须继续遵循EPL开源协议来发布,而不能改用其他协议发布.除非你得到了原"源码"Owner 的授权;
+EPL协议下,你可以将源码不做任何修改来商业发布.但如果你要发布修改后的源码,或者当你再发布的是 Object Code 的时候,你必须声明它的 Source Code 是可以获取的,而且要告知获取方法;
+当你需要将EPL下的源码作为一部分跟其他私有的源码混和着成为一个 Project 发布的时候,你可以将整个 Project/Product 以私人的协议发布,但要声明哪一部分代码是EPL下的,而且声明那部分代码继续遵循EPL;
+4.独立的模块(Separate Module),不需要开源。
+Creative Commons (CC) 许可协议并不能说是真正的开源协议,它们大多是被使用于设计类的工程上。 CC 协议种类繁多,每一种都授权特定的权利。 一个 CC 许可协议具有四个基本部分,这几个部分可以单独起作用,也可以组合起来。下面是这几部分的简介:
+署名 作品上必须附有作品的归属。如此之后,作品可以被修改,分发,复制和其它用途。
+相同方式共享 作品可以被修改、分发或其它操作,但所有的衍生品都要置于CC许可协议下。
+非商业用途 作品可以被修改、分发等等,但不能用于商业目的。但语言上对什么是"商业"的说明十分含糊不清 (没有提供精确的定义),所以你可以在你的工程里对其进行说明。例如,有些人简单的解释"非商业"为不能出售这个作品。而另外一些人认为你甚至不能在有广告的网站上使用它们。 还有些人认为"商业"仅仅指你用它获取利益。
+禁止衍生作品
+CC 许可协议的这些条款可以自由组合使用。大多数的比较严格的CC协议会声明 "署名权,非商业用途,禁止衍生"条款,这意味着你可以自由的分享这个作品,但你不能改变它和对其收费,而且必须声明作品的归属。这个许可协议非常的有用,它可以让你的作品传播出去,但又可以对作品的使用保留部分或完全的控制。最少限制的CC协议类型当属 "署名"协议,这意味着只要人们能维护你的名誉,他们对你的作品怎么使用都行。
+CC 许可协议更多的是在设计类工程中使用,而不是开发类,但没有人或妨碍你将之使用与后者。只是你必须要清楚各部分条款能覆盖到的和不能覆盖到的权利。
+前言 讲起播客,许多人第一反应是喜马拉雅,但其实播客的订阅和收听有许多种方式。本文带你了解订阅播客的各种方式,并告诉你市面上有哪些不错的播客客户端可供选择。
+播客是一种通过互联网传播音频或视频文件的媒体形式。这个词汇是由“广播”(broadcasting)和“iPod”(一种流行的便携式媒体播放器)两个词组合而成的。播客通常是由个人、组织或公司制作,并通过互联网上的订阅服务分享给观众。
+定期更新: 播客通常以系列形式发布,每一集都是一个独立的音频或视频文件。制作者会定期发布新的内容,让观众订阅后能够定期收听或观看。
+订阅:观众可以通过订阅播客来自动获取最新的内容。这意味着一旦订阅了某个播客,新的内容就会自动下载到用户的设备上,方便随时收听或观看。
+多样的内容: 播客内容非常多样化,涵盖了几乎所有可能的主题,包括新闻、科技、文化、教育、娱乐等。从个人讲述生活故事到专业领域的讨论,播客的形式和内容都非常灵活。
+低门槛制作:制作播客相对来说不需要太多的专业设备和技能,因此许多个人或小团队可以轻松开始制作自己的播客。
+播客的流行得益于它提供了一种轻松、灵活、个性化的信息传递方式,让人们可以方便地在各种主题上深入了解或娱乐。
+要收听播客,首先得确定自己所用的平台和客户端,一般有以下几种:
+使用播客应用: 最常见的方式是使用专门的播客应用程序,这些应用可以在智能手机、平板电脑或计算机上安装。一些常见的播客应用包括 Apple Podcasts(苹果播客)、Spotify、Google Podcasts(谷歌播客)、Pocket Casts等。这些应用通常允许你搜索、订阅和播放播客。像喜马拉雅以及各大云音乐等非泛用型播客客户端,这类软件的特点是收听方便,种类繁多,但一般不开源,也没有 RSS 链接。
+在网页上收听: 许多播客也提供在其官方网站上在线收听的选项。你可以在制作者的网站上找到相应的播客链接,然后直接在浏览器中收听,或者使用浏览器插件。
+通过流媒体服务: 一些流媒体服务,如 Spotify、Apple Music 等,也提供了播客的功能。你可以在这些服务中搜索并订阅你感兴趣的播客。
+通过RSS订阅: 几乎每个独立播客的主播都会反复强调「请使用节目 RSS 链接在 泛用型播客客户端 里订阅节目」,一定程度上有无 RSS 订阅链接是作为独立播客的判断标准。使用 RSS 链接订阅播客其实非常简单——得到节目的 RSS 订阅链接后,将之粘贴到你的播客客户端内(通常是节目的搜索栏或地址栏)即可。大多数播客应用都支持这种方式。注意,例如喜马拉雅、荔枝等平台是没有原生RSS链接的,因此,对第三方服务生成的 RSS 链接要注意鉴别。有些服务提供者会在不告知主播和听众的前提下,私自在节目中间插入广告,非常影响节目收听体验,在使用时请注意甄别。
+我个人推荐使用开源的 AntennaPod 。
前言 RSS 提供了一种数据格式,以 XML(可扩展标记语言)的形式组织信息,包括文章标题、摘要、链接和发布日期等。这些信息形成了所谓的“订阅源”(Feed),用户可以使用RSS阅读器(Feed Reader)来订阅这些源。
+如果你使用过类似红板报,轻芒杂志,摸鱼 kiki,今日热榜等 APP,应该对 RSS 并不陌生。
+RSS(Really Simple Syndication)是一种用于发布经常更新的内容的标准,通常用于博客、新闻网站和其他线上发布的信息。RSS 允许用户订阅这些站点的内容,以便在内容有更新时,用户能够获得及时的通知。
+基本上,RSS 提供了一种数据格式,以 XML(可扩展标记语言)的形式组织信息,包括文章标题、摘要、链接和发布日期等。这些信息形成了所谓的“订阅源”(Feed),用户可以使用 RSS 阅读器(Feed Reader)来订阅这些源。
+RSS 的主要优势包括:
+即时通知:用户订阅了 RSS 源后,当源中的内容有更新时,用户将立即收到通知,而无需手动检查网站。
+集中管理:使用 RSS 阅读器,用户可以集中管理多个网站的更新,而无需逐个访问这些站点。
+隐私保护:RSS 订阅不需要提供个人信息,用户只需关注感兴趣的内容,而无需注册账户。
+定制内容:用户可以选择订阅感兴趣的主题或网站,定制他们的信息流。
+减少信息过载:通过只关注真正感兴趣的内容,用户可以减少信息过载,集中注意力在最关键的信息上。
+如果我们想更高效地获取信息,不在多个应用间来回切换,另一方面拒绝算法给我们推荐的内容,那么建议用回原始的 RSS。
+虽然 RSS 曾经非常流行,但随着社交媒体和其他信息传递方式的兴起,逐渐成为时代的眼泪。然而,RSS 仍然是一种有效的信息分发和获取方式,许多网站和博客仍提供 RSS 源。题主曾经计划使用 Kindle 作为专门的RSS阅读器,后来由于过于昂贵而作罢。
+基本上有以下几步:
+寻找 RSS 订阅源
+确定 RSS 客户端
+自建 RSS 服务端(可选)
+寻找RSS订阅源
+要知道一个网站是否支持 RSS 订阅,最直接的方法就是看网站的底部或侧边栏是否有 RSS 图标。一般来说,图标所指向的地址就是该网站的订阅链接,可以直接点击 跳转到 RSS 客户端内进行订阅,也可以复制粘贴按钮中的地址到自己在用的 RSS 服务中订阅这些网站中的内容。
+在浏览器中推荐使用 RSS Hub radar 插件,可以自动找到可用的RSS源并提示。
+有时候网站不会直接给出订阅源,这时候你也可以尝试在网站域名后面加上 /feed 或 /rss 或许可以碰巧猜中,比如少数派的 RSS 订阅链接就是 https://sspai.com/feed。当然,你也可以直接通过搜索引擎通过 网站名 + RSS 的关键字进行搜索,往往都能找到支持网站的 RSS 链接。
+MoreRSS,这个网站提供中、英文的RSS源,并且显示源的订阅量,对于一些受欢迎的英文 RSS,还提供了中文翻译。但此网站还在建设中,收录量不大、功能也不完善,可以关注其更新。
+有一些中文博客聚合网站,收录了多则1000+少则几百的中文博客(PS.经查世界上现存的大熊猫数量约2600只),知名的有十年之约、博友圈、BlogFinder 、积薪、川流 等,不一一列举了。
+Feedsearch,如果在网站的首页看不到 RSS 信息,可以使用这个 RSS 源搜索服务,实测准确度很高,我用它找出来很多隐藏的 RSS 源,如果这个网站搜不到,那可能是网站确实没有提供 RSS。
+RSSAnything ,如果 RSSHub 也没有找到需要的 RSS,可以尝试使用这个网站生成 RSS,这是我试过的效果最好的,但要看运气,有的时候效果很好,有的时候达不到期望值。
+有一些针对具体的社会化媒体生成 RSS 的服务,但或者收费,或者稳定性欠佳失效,或者收费且稳定性欠佳失效(我就订阅了一个微信公众号的 RSS 服务,没用多久就失效了还不退款),想了下,就不在这里列举了,感兴趣可以直接在https://morerss.com/tools_zh.html查找。
+++英文RSS源翻译
+
+可以把外语信息源翻译为中文的,这里推荐的服务器是 RSS-Translator,功能强大但需要一定的能力。MoreRSS 基于 RSS-Translator 的服务,翻译了一批优质的外语信息源,可以直接订阅。
当然,我们也可以直接导入现有的订阅源,一般为 OPML 文件,如 RSS Source;或者调用第三方的 RSS 服务,如 anyfeeder,等等。
+这里介绍一个 RSS 神器,由 DIygod 发起的RSShub项目:
+RSSHub 是一个开源项目,旨在为用户提供一个集中化、可定制的RSS(Really Simple Syndication)源的生成器。该项目的目标是通过从各种网站和平台获取信息,将其聚合到用户自定义的RSS源中,从而使用户能够方便地订阅他们关心的内容。
+开源性质: RSSHub 是一个开源项目,其源代码可以在 GitHub 上找到。这意味着任何人都可以查看、使用、修改和贡献代码。
+支持的站点: RSSHub 支持从各种网站和平台提取数据,包括但不限于新闻网站、社交媒体、博客、视频分享平台等。用户可以根据自己的需求选择要订阅的站点。
+自定义生成: 用户可以通过指定参数和规则来定制他们的 RSS 源,以便获取特定主题或关键字的更新。这使得用户能够灵活地定制他们的订阅流。
+社区参与: RSSHub 是一个社区驱动的项目,有很多开发者和贡献者参与其中。社区可以通过 GitHub 进行讨论、报告问题和提交代码。
+部署方式: RSSHub 可以自行部署,用户可以在自己的服务器上搭建RSSHub实例,以便更好地控制和定制生成的RSS源。
+确定RSS客户端
+RSS客户端非常丰富,包括 Android 端,IOS 端,Windows 端,linux 端,浏览器插件,甚至 Vscode 插件(用来摸鱼)等等。这里推荐一些阅读器,当然,也可以选择类似 Feedly 的服务商。
+Android:News,在Fdorid里可下载,中文名为“新闻”,界面简洁,功能全面,支持本地或连接自建服务端。
+IOS:Inoreader, 其提供了方便的阅读体验,支持离线阅读、标签和快速搜索。
+Windows:Fluent Reader,在github上开源,界面优雅,支持本地或连接自建服务端。
+linux:Fluent Reader或Newsboat, 是 Newsbeuter 的一个分支,一款文本控制台 RSS/Atom 订阅阅读器。
+自建RSS服务端
+开源的RSS服务端软件可以用来搭建个人的RSS阅读服务:
+FreshRSS: FreshRSS 是一款简单易用的自建 RSS 服务端软件。它提供了丰富的功能,包括标签、筛选器、阅读统计等,并支持多用户。
+Miniflux: Miniflux 是一个轻量级的 RSS/Atom 阅读器服务,支持自建。它采用 Go 语言编写,具有快速响应和简洁的用户界面。
+Tiny Tiny RSS (tt-rss): Tiny Tiny RSS 是一款功能丰富的自建RSS服务端软件,提供了类似于 Google Reader 的界面,并支持标签、过滤器、插件等。
+Selfoss: Selfoss 是一款支持多种数据源(包括RSS)的自建聚合器。它的界面简洁,支持标签、过滤器和插件,同时也提供了跨平台的客户端。
+Miniflux 2: 不要与上面提到的 Miniflux 混淆,Miniflux 2 是 Miniflux 的一个全新版本,同样支持自建 RSS 服务。
+这里以MiniFlux为例,其优势在与:
+程序设计极简,不处理任何订阅之外的事情。
+程序无外部依赖,运行性能高。
+支持自动抓取并缓存图片,加速浏览。
+有限支持自动将摘要替换为全文进行抓取。
+支持多账号登录,支持 Fever API ,允许客户端从外部登录。
+支持集成 PinBoard 、Instapaper、 Pocket、Wallabag、Nunux Keeper 等服务。
+提供 Open API、书签快速订阅脚本。
+维护者和社区相对活跃,更新频率高。
+步骤:
+1.安装docker 和docker-compose(略)
+2.Docker 安装 miniflux:
+(1)创建并进入你想安装 Miniflux 的文件夹:
+mkdir ~/miniflux # 在根目录创建名为miniflux的文件夹
cd ~/miniflux # 进入miniflux文件夹
(2)创建docker-compose.yml文件:
+nano docker-compose.yml # 使用nano编辑器创建,会自动打开文件以写入内容
(3)在文件中写入以下内容并保存:
+version: '3.4'
+
+services:
+
+ miniflux:
+
+ image: miniflux/miniflux:latest
+
+ ports:
+
+ - "127.0.0.1:8080:8080" #调整一:增加localhost ip 并改port为8080
+
+ depends_on:
+
+ - db
+
+ environment:
+
+ - DATABASE_URL=postgres://miniflux:secret@db/miniflux?sslmode=disable
+
+ - RUN_MIGRATIONS=1
+
+ - CREATE_ADMIN=1
+
+ - ADMIN_USERNAME=admin # 登录Miniflux的用户名,可自定义
+
+ - ADMIN_PASSWORD=password # 登录Miniflux的密码,可自定义,至少6位
+
+ - "BASE_URL=https://enter.your.url" # 调整二:输入想用来访问Miniflux的域名
+
+ healthcheck:
+
+ test: ["CMD", "/usr/bin/miniflux", "-healthcheck", "auto"]
+
+ db:
+
+ image: postgres:latest
+
+ environment:
+
+ - POSTGRES_USER=miniflux
+
+ - POSTGRES_PASSWORD=secret
+
+ volumes:
+
+ - miniflux-db:/var/lib/postgresql/data
+
+ healthcheck:
+
+ test: ["CMD", "pg_isready", "-U", "miniflux"]
+
+ interval: 10s
+
+ start_period: 30s
+
+volumes:
+
+ miniflux-db:
+
+该 docker-compose.yml 文档内容基于 Miniflux 官方文档 ,并在细节上进行了调整。调整有两处:一是将 port 改为127.0.0.1:8080:8080,主要目的是错开常用port 80,并调整 localhost 为127.0.0.1来跟 nginx 的设置一致(如不调整, miniflux 将使用0.0.0.0,无法顺利运行 nginx );二是在 miniflux 的environment 中加入新的 configuration BASE_URL,请将内容换为你想用来访问 Miniflux 的域名。
+//如何用 nano 保存文件:可以使用 ctrl+X,在退出编辑时,选择Y来保存所有更改,再敲一次回车便可以回到命令行。//
+(4)运行以下代码进行安装:
+docker-compose up -d
在浏览器中访问服务器ip:端口号(如http://123.45.67.890:8080),如显示登录界面,即代表安装成功。域名解析和反代步骤略。
+前言 本文记录服务器常用操作步骤。
+建站不一定需要服务器、域名和备案。尤其不要买腾讯云,不要买CN域名;备案过程要填很多个人信息,且一周没有解析网站,备案就会自动注销。
+cn 域名没有隐私保护(whois protection)。国内域名注册商说的隐私保护根本是自欺欺人,在它们隐私保护就是在自己的查询服务隐藏注册人信息。但在别的地方是能查到的,在中国互联网络信息中心可以查到每个 cn 域名注册人的姓名和邮箱。
+注册 cn 域名必须使用真实身份信息。要是你想用假信息注册来保护隐私,那就太天真了。审核的时候不会通过的。真的不想用自己的信息注册的话,要么以公司名义注册,但公司的法定代表人还是能查到的。要么叫别人注册域名之后给你用,可谁愿意冒这种风险呢。
+cn 域名无法删除。如果你觉得 cn 域名暴露了你的隐私,那对不起,这是不能注销的3。你只能修改邮箱地址,然后等到它过期。或者转让给别人,不过感觉把别人推到火坑里不太好啊。
+cn 域名有被停用的风险。2008 年,有人以跳水奥运冠军吴敏霞拼音注册了 wuminxia.cn,结果被中国互联网络信息中心(CNNIC)回收了域名,并转交给国家体育总局。此域名在 2021 年 2 月 28 日被优视科技注册,呵呵。2009 年,牛博网被域名注册商万网停止解析。
+# 更新系统
+apt update && apt upgrade -y
+apt install wget curl vim sudo neofetch
+# 创建用户并赋予sudo
+adduser xxx
+sudo usermod -aG sudo xxx
+
+sysctl net.ipv4.tcp_available_congestion_control
+
+sysctl net.ipv4.tcp_congestion_control
+
+echo net.ipv4.tcp_congestion_control=bbr >> /etc/sysctl.conf && sysctl -p
+
+++使用密码登录:更换SSH端口+安装UFW+安装Fail2ban +使用密钥登录:不用额外操作
+
使用root账户或已经有sudo权限的用户登录到系统。
+打开SSH配置文件sshd_config,可以使用文本编辑器如nano或vi。以下是使用nano编辑器的示例:
sudo vim /etc/ssh/sshd_config
+
+在配置文件中找到以下行:
+Port 22
+
+这是SSH默认的端口号,你可以将其更改为你想要的任何未被占用的端口号。例如,将端口更改为2222:
+Port 2222
+
+保存并关闭文本编辑器。重新启动SSH服务,以应用更改:
+sudo service ssh restart
+
+或者,如果你的系统使用systemd,可以使用以下命令:
+sudo systemctl restart ssh
+
+sudo apt install ufw
+
+如果你在远程位置连接你的服务器,在启用 UFW 防火墙之前,你必须显式允许进来的 SSH 连接。否则,你将永远都无法连接到机器上。
+sudo ufw allow 22/tcp
+
+++如果 SSH 运行在非标准端口,你需要将上述命令中的 22 端口替换为对应的 SSH 端口。
+
启动 UFW
+sudo ufw enable
+
+sudo apt-get install fail2ban
+
+2、Debian 12 及以上的版本需要手动安装 rsyslog
+sudo apt-get install rsyslog
+
+3、启动 Fail2ban 服务
+sudo systemctl start fail2ban
+
+4、开机自启动
+sudo systemctl enable fail2ban
+
+5、查看 Fail2ban 服务状态。
+sudo systemctl status fail2ban
+
+ssh-keygen
+
+注意不同密钥对名称不能相同;同时可以为这两个文件用密码加密;
+随后将.pub后缀的公钥中的内容写入服务器的~/.ssh/authorized_keys中;
使用以下命令编译服务器的SSH配置:
+vim /etc/ssh/sshd_config
+
+将其中的该行改为PasswordAuthentication no,保存退出;随后使用
sudo systemctl restart sshd
+
+重启SSH即可禁用密码登录;
+将PermitRootLogin一栏改为PermitRootLogin prohibit-password,即可实现仅root用户密钥登录;
+使用以下命令查看输出,
+sudo cat /etc/ssh/sshd_config | grep -E 'PasswordAuthentication|PubkeyAuthentication'
+
+如有PasswordAuthentication no → 禁用密码登录以及PubkeyAuthentication yes → 允许密钥登录则成功。
+++注意authorized_keys的权限为600,如果不是则需要改正:
+chmod 600 ~/.ssh/authorized_keys
apt install curl wget gpg vim nano sudo neofetch openssh-server
+
+sudo apt install build-essential gdb cmake clangd clang-format libstdc++-dev
+
+wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh
+bash Miniconda3-latest-Linux-x86_64.sh
+
+curl -LsSf https://astral.sh/uv/install.sh | sh
+
+curl -fsSL https://get.docker.com -o get-docker.sh
+sudo sh get-docker.sh
+
+sudo apt install tree libx11-dev libgtk-3-dev freeglut3-dev libopencv-dev libdlib-dev
+
+sudo apt install open-vm-tools
+sudo apt install open-vm-tools-desktop
+
+++Vscode无法连接:需要删除本地存储的错误密钥,powershell:
+
(Get-Content "$env:USERPROFILE\.ssh\known_hosts") |
+Where-Object { $_ -notmatch '<你的IP>' } |
+Set-Content "$env:USERPROFILE\.ssh\known_hosts"
+
+执行如下命令一键安装 1Panel:
+curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o quick_start.sh && sudo bash quick_start.sh
+
+手动 禁用 VPS 的 IPv6 命令:
+sysctl -w net.ipv6.conf.all.disable_ipv6=1
+sysctl -w net.ipv6.conf.default.disable_ipv6=1
+
+如果想重启系统也生效, 执行:
+echo 'net.ipv6.conf.all.disable_ipv6=1' >> /etc/sysctl.conf
+echo 'net.ipv6.conf.default.disable_ipv6=1' >> /etc/sysctl.conf
+
+手动 启用 VPS 的 IPv6 命令:
+sysctl -w net.ipv6.conf.all.disable_ipv6=0
+sysctl -w net.ipv6.conf.default.disable_ipv6=0
+
+重新载入 sysctl 配置
+sysctl --system # reload sysctl
+
+如果重载, 还无效果, 可能要 reboot 重启下. +查看 VPS 的 IPv6 信息
+ip -6 addr show scope global
+
+或者 curl ipv6.ip.sb
+
+在 ZeroSSL 中申请一个90天的证书;
+然后在VPS上输入以下命令:
+mkdir -p ./.well-known/pki-validation
+
+随后在ZeroSSL中将所给出的类似B992F08CB46748D02E4C553A4038BC.txt复制;
+将从ZeroSSL下载得到的文件打开,复制里面的东西形成以下的格式:将pki-validation/之后EOF之前的内容替换为你自己的。
cat << EOF | sudo tee ./.well-known/pki-validation/B992F08CB46748D02E4C553A4038BC.txt
+254563C20918258D661E7D43D6A43A2A258857E191977DD5F740FBB9ABD25279
+comodoca.com
+ca5792984e3f0a1
+EOF
+
+随后在VPS上运行该命令。
+python3 -m http.server 80
+
+通过恢复模式 (Recovery Mode) 修改用户权限:
+重启计算机,按住 Shift 键进入 GRUB 菜单(或者按 Esc 键)。
+在 GRUB 菜单中,选择Advanced options for Ubuntu然后选择带有recovery mode的内核版本。
进入恢复模式后,选择root – Drop to root shell prompt进入 root shell(不需要密码)。
挂载文件系统为可写模式:
+mount -o remount,rw /
+
+usermod -aG sudo 用户名
+
+reboot
+
+以Xanmod为例:
+echo 'deb [signed-by=/usr/share/keyrings/xanmod.gpg] http://deb.xanmod.org releases main' | sudo tee /etc/apt/sources.list.d/xanmod.list
+curl -fsSL https://dl.xanmod.org/gpg.key | gpg --dearmor | sudo tee /usr/share/keyrings/xanmod.gpg > /dev/null
+
+sudo apt update
+
+apt search xanmod
+sudo apt install linux-image-6.8.6-x64v3-xanmod1 linux-headers-6.8.6-x64v3-xanmod1
+
+| 后缀示例 | 含义简述 | 适合用途 |
|---|---|---|
xanmod1, xanmod2, … | 主线 XanMod 版本编号(带通用优化) | 桌面、通用、游戏 |
x64v3-xanmod1 | 针对 x86_64-v3 架构优化(AVX2 以上指令集) | 高性能桌面、较新 CPU(2011+) |
rt-xanmod1 | 实时(RT)内核,用于极低延迟任务 | 音频制作、工业控制 |
lts-xanmod1 | 长期支持版本(LTS) | 服务器、稳定性优先 |
edge-xanmod1 | 更前沿、不稳定的测试版本 | 喜欢尝鲜的高级用户 |
x64v2-xanmod1, x64v4-… | 针对特定 微架构(CPU 指令集) 的优化版本 | 有特定硬件支持的系统 |
你可以用以下命令检测你的 CPU 是否支持 x64v3:
lscpu | grep avx2
+
+如果输出中有 avx2,就可以用 x64v3 版本。
sudo update-grub
+sudo reboot
+uname -r
+
+查看已安装内核:
+dpkg --list | grep linux-image
+
+移除旧的:
+sudo apt remove linux-image-5.10.0-26-amd64
+
+如果你想默认引导到 XanMod 内核:
+编辑 /etc/default/grub:
GRUB_DEFAULT="Advanced options for Debian>Debian, with Linux 6.8.6-x64v3-xanmod1"
+
+然后:
+sudo update-grub
+
+除了到VPS后台更换外,还可以使用这个脚本:
+ +一键重装到 Linux,支持 19 种常见发行版
+一键重装到 Windows,使用官方原版 ISO 而非自制镜像,脚本支持自动查找 ISO 链接、自动安装 VirtIO 等公有云驱动
+支持任意方向重装,即 Linux to Linux、Linux to Windows、Windows to Windows、Windows to Linux
+自动设置 IP,智能设置动静态,支持 /32、/128、网关不在子网范围内、纯 IPv6、IPv4/IPv6 在不同的网卡
+专门适配低配小鸡,比官方 netboot 需要更少的内存
+全程用分区表 ID 识别硬盘,确保不会写错硬盘
+支持 BIOS、EFI 引导,支持 ARM 服务器
+不含自制包,所有资源均实时从镜像源获得
+
+Done.
+ +前言 在日常使用浏览器时,掌握一些快捷键和技巧可以节省大量时间,提高工作和学习效率。通过学习和实践,能够更加轻松地应对各种网页浏览场景,让浏览器成为工作和学习的得力助手。
+| 快捷键 | 描述 |
|---|---|
| Ctrl + A | 全选 |
| Ctrl + C | 复制 |
| Ctrl + X | 剪切 |
| Ctrl + V | 粘贴 |
| Ctrl + F | 查找 |
| Ctrl + Q | 退出 |
| Ctrl + T | 新建标签页 |
| Ctrl + W | 关闭标签页 |
| Ctrl + N | 新建窗口 |
| Ctrl + Shift + P | 新建隐私浏览窗口 |
| 快捷键 | 描述 |
|---|---|
| Ctrl + H | 历史侧栏 |
| Ctrl + Shift + H | 我的足迹窗口(历史) |
| Ctrl + Shift + Del | 清除最近历史记录 |
| 快捷键 | 描述 |
|---|---|
| Ctrl + D | 将此页加为书签 |
| Ctrl + I | 页面信息 |
| Ctrl + Shift + O | 显示全部书签(我的足迹窗口) |
| Ctrl + B / Ctrl + Shift + B | 书签侧栏 / 顶栏 |
| 快捷键 | 描述 |
|---|---|
| Ctrl + Shift + Y | 下载 |
| Ctrl + Shift + A | 附加组件 / 插件 |
| 快捷键 | 描述 |
|---|---|
| Ctrl + Shift + K | Web 控制台 |
| Ctrl + Shift + C | 查看器 |
| Shift + F7 | 样式编辑器 |
| Shift + F5 | 分析器 |
| Ctrl + Shift + E | 网络 |
| Ctrl + U | 页面源码 |
| Ctrl + Shift + J | 浏览器控制台 |
| 快捷键 | 描述 |
|---|---|
| Ctrl + S | 界面保存 |
| Ctrl + + | 放大 |
| Ctrl + - | 缩小 |
| Ctrl + 0 | 重置缩放 |
| Ctrl + K / J | 搜索 |
| Ctrl + Home / End | 到文件头 / 尾 |
| Ctrl + Page Up | 切换到左边标签页 |
| Ctrl + Page Down | 切换到右边标签页 |
| Ctrl + Shift + Page Up | 当前标签页左移 |
| Ctrl + Shift + Page Down | 当前标签页右移 |
| 快捷键 | 描述 |
|---|---|
| Alt + Space | KDE 搜索栏 |
| Alt + → / ← | 前进 / 后退 |
| Alt + 数字键 | 选择标签页(1–8) |
| Alt + M | 静音 |
| End | 到达页尾 |
| Home | 到达页首 |
| F6 | 地址栏 |
| 快捷键 | 描述 |
|---|---|
cmd + shift + e | 文件资源管理器 |
cmd + shift + f | 跨文件搜索 |
ctrl + shift + g | 源代码管理 |
cmd + shift + d | 启动和调试 |
cmd + shift + x | 扩展管理 |
cmd + shift + p | 查找并运行所有命令 |
cmd + j | 打开、关闭面板 |
| 命令 | 描述 |
|---|---|
code $path | 新窗口中打开文件或文件夹 |
code -r $path | 窗口复用打开文件 |
code -r -g $file:lineno | 打开文件并跳转到指定行 |
code -r -d $file1 $file2 | 比较两个文件 |
ls code - | 查看可用命令 |
| 快捷键 | 描述 |
|---|---|
option + 左/右方向键 | 按单词移动光标 |
cmd + 左/右方向键 | 移动到行首/行尾 |
cmd + shift + \ | 在花括号之间跳转 |
cmd + 上/下方向键 | 移动到文档首/尾 |
shift + 光标移动 进行文本选择。| 快捷键 | 描述 |
|---|---|
cmd + fn + del | 删除到行尾 |
cmd + del | 删除到行首 |
option + del | 向前删除单词 |
option + fn + del | 向后删除单词 |
| 快捷键 | 描述 |
|---|---|
cmd + shift + k | 删除行 |
cmd + x | 剪切行 |
cmd + enter | 在当前行下方插入新行 |
cmd + shift + enter | 在当前行上方插入新行 |
option + 上/下方向键 | 移动当前行 |
option + shift + 上/下方向键 | 复制当前行 |
cmd + / | 注释/取消注释当前行 |
option + shift + a | 注释/取消注释代码块 |
option + shift + f | 格式化代码 |
cmd + k cmd + f | 格式化选中代码 |
ctrl + t | 调换光标前后字符 |
cmd + shift + p + transform to up/low case | 转换大小写 |
ctrl + j | 合并代码行 |
cmd + u | 撤销光标移动 |
option + 鼠标左键| 快捷键 | 描述 |
|---|---|
cmd + option + 上/下方向键 | 创建多个光标 |
cmd + d | 选中相同单词并创建多个光标 |
option + shift + i | 在选中的多行后创建光标 |
| 快捷键 | 描述 |
|---|---|
ctrl + tab | 文件标签之间跳转 |
cmd + p | 打开文件列表 |
| 快捷键 | 描述 |
|---|---|
ctrl + g | 跳转到指定行 |
| 快捷键 | 描述 |
|---|---|
cmd + shift + o | 当前文件所有符号列表 |
@: | 符号分类排列 |
cmd + t | 在多个文件中进行符号跳转 |
cmd + F12 | 跳转到函数的实现位置 |
shift + F12 | 查看函数引用列表 |
ctrl + - | 跳回上一次光标所在位置 |
ctrl + shift + - | 跳回下一次光标所在位置 |
| 快捷键 | 描述 |
|---|---|
ctrl + space | 调出建议列表 |
cmd + shift + space | 调出参数预览窗口 |
cmd + . | 快速修复建议列表 |
F2 | 函数名重构 |
| 快捷键 | 描述 |
|---|---|
cmd + option + [ | 最内层折叠 |
cmd + option + ] | 最内层展开 |
cmd + k cmd + 0 | 全部折叠 |
cmd + k cmd + j | 全部展开 |
| 快捷键 | 描述 |
|---|---|
cmd + f | 搜索 |
cmd + g | 搜索并跳转 |
cmd + option + f | 查找替换 |
cmd + shift + f | 多文件搜索 |
| 快捷键 | 描述 |
|---|---|
cmd + \ | 拆分编辑器 |
option + cmd + 左/右方向键 | 编辑器间切换 |
cmd + 数字键 | 在拆分的编辑器窗口跳转 |
cmd + / | 缩放整个工作区 |
cmd + shift + p + reset zoom | 重置缩放 |
| 快捷键 | 描述 |
|---|---|
cmd + b | 打开或关闭侧边栏 |
cmd + j | 打开或关闭面板 |
cmd + shift + p + Toggle Zen Mode | 切换禅模式 |
cmd + shift + p + Toggle Centered Layout | 切换居中布局 |
| 快捷键 | 描述 |
|---|---|
cmd + shift + p | 打开命令面板 |
命令面板的前缀符号功能:
+?:列出所有可用功能>:显示所有命令@:显示并跳转文件中的符号@::按类别归类符号#:显示并跳转工作区中的符号::跳转到当前文件中的某一行edt:显示所有已打开的文件edt active:显示当前活动组中的文件ext:插件管理ext install:搜索和安装插件task:任务管理debug:调试功能term:创建和管理终端实例view:打开各个 UI 组件| 快捷键 | 描述 |
|---|---|
ctrl + w | 关闭当前窗口 |
ctrl + r | 切换文件夹 |
ctrl + r + cmd + enter | 新建窗口打开文件夹 |
| 快捷键 | 描述 |
|---|---|
| `ctrl + `` | 切换集成终端 |
| `ctrl + shift + `` | 新建集成终端 |
cmd + shift + p + Run Active File In Active Terminal | 在终端中运行当前文件 |
cmd + shift + p + Run Selected Text In Active Terminal | 在终端中运行选中文本 |
| 快捷键 | 描述 |
|---|---|
cmd + shift + p + run task | 自动检测可运行的任务 |
cmd + shift + p + Configure Task | 配置任务 |
cmd + shift + b | 运行默认的生成任务 |
文本选择:
+文本编辑:
+option:复制文本函数提示:
+cmd:提示函数的实现Done.
+ +前言 本文记录着无器械健身理论以及相关的读后感。
+人类的发展史决定了增肥比减肥容易,脂肪的快速积累能力保障了我们的祖先在冰河/饥荒/战乱年代的生存,否则将带来极大的生存劣势;而如今食物的匮乏在大多数国家已经不是问题,肥胖/超重问题频发。
+++BMI身体质量指数(Body Mass Index)计算:体重kg/身高(m)2,如体重70kg,身高1.75m,则BMI为22.86.
+
| BMI 值 | 体重分类 |
|---|---|
| < 18.5 | 体重过轻 |
| 18.5 ~ 23.9 | 正常范围 |
| 24 ~ 27.9 | 超重 |
| 28 及以上 | 肥胖 |
提高五大综合水平
+自体重训练完全可以达到预期效果,实现简单方便,无须复杂器械。
+未完待续...
+ +前言 Ventoy 是一款开源免费的多系统启动盘制作工具,这里说明其主要功能的制作流程。
+Ventoy 是一款开源免费的多系统启动盘制作工具,旨在简化操作系统的安装过程。与传统的启动盘制作方法不同,Ventoy 允许用户将多个操作系统的镜像文件如 ISO、WIM、IMG、VHD(x)、EFI 等直接复制到 U 盘,无需反复格式化或使用专门的工具写入镜像。

++PE启动盘 / ISO系统安装盘 / Win-to-go / Linux-to-go / 文件存储 五功能合一
+
在官网下载Ventoylanguage中改为中文显示,可以看到左上角有配置选项GPT,开启安全启动支持;分区格式设置为NTFS;分区设置中进行分区,选择在磁盘后保留一段空间,这里的空间将不被分区,即为空闲空间,可以当作普通的文件存储盘;U盘总容量-保留空间-ventoy保留分区的空间新建一个盘,这里可以放ISO、WIM、IMG、VHD(x)、EFI等等选择磁盘并开始安装;BIOS Legacy模式 或 UEFI 模式启动。++注意不可在PE环境下安装Ventoy!
+
使用DiskGenius或其他磁盘工具,可以看到刚刚制作的磁盘有两个分区:ventoy保留分区(有文件)和Ventoy分区(无文件)以及一个空闲空间。
将空闲空间格式化并新建磁盘,随后会出现一个新的可用盘,可以用这个盘进行存储。
将PE的ISO文件放入Ventoy分区即可。常用PE:
+ +将要安装的系统的ISO镜像放入Ventoy分区即可。常用系统:
+Ventoy 使用名为ventoy_vhdboot插件来支持直接启动 VHD(x) 文件(Win7以上).支持 Legacy BIOS 和 UEFI 模式。支持固定大小以及动态扩展类型的 VHD/VHDX 格式。
从下面任意一个链接中下载ventoy_vhdboot.img文件即可(几个链接中的文件都是一样的)。
把下载后的文件放在U盘第1个分区(就是放ISO文件的分区)的 ventoy 目录下(默认没有这个目录,需手动创建,注意大小写),即 /ventoy/ventoy_vhdboot.img 就可以了。
随后将vhd或vhdx后缀的Windows虚拟机镜像放入其中即可出现在启动栏。
+++可以使用Virtualbox创建Windows虚拟机并将镜像复制到ventoy中。
+
Ventoy 使用plugin_vtoyboot插件来支持在物理机上直接启动安装了 Linux系统的 vdisk 文件 (vhd/vdi/raw 等)。这种模式的优点有:
没有性能损失。既可以在 Legacy BIOS 模式下启动,也可以在 UEFI 模式下启动。无需独占一个磁盘或者分区,相当于把一个完整的Linux系统放在一个文件里。 比如,你的主系统是 C 盘里的 Windows 系统,你可以在D盘里放一些支持的 vdisk 格式:
+固定大小的 vhd (注意只能是vhd, 不支持vhdx)固定大小的 vdiRaw Disk 镜像格式VirtualBox中创建固定大小的 vhd/vdi,注意只支持静态大小的,不支持动态扩展类型的。然后把支持的 Linux 系统安装到 vhd/vdi 中即可。
注意:
+虚拟硬盘必须是全新创建的,不能使用之前用过的。必须设置为 UEFI 模式!不能对虚拟机创建快照,否则会导致 vdi/vhd 无法识别。有一些系统安装完之后还需要再额外安装一个 grub 的包才可以,否则最终的 vhd/vdi 文件只能在 UEFI 模式下启动,无法在 Legacy BIOS 模式下启动。对于这种,在前面表格最后的 "备注" 一栏有说明,没有特殊说明的就不需要。详见Linux vDisk 文件启动插件
+安装完成并启动到 Linux 系统中之后,执行 vtoyboot 脚本。这一步是为了在系统中做一些处理,以支持Ventoy启动。
+vtoyboot 是配套 Ventoy 开发的一个项目,单独发布。从 https://github.com/ventoy/vtoyboot/releases 下载压缩包即可。
+下载到 Linux 系统中,解压,然后以root权限执行里面的脚本 sudo bash vtoyboot.sh 脚本执行完之后,使用 poweroff 命令关机。
+注意 vtoyboot 会经常更新以支持更多的 Linux 版本以及修复 BUG,所以请使用最新版本。
+++如果是对内核、驱动进行了升级、或者类似于通过 dnf update 命令进行了系统的大升级之后, 建议再重新执行一次 vtoyboot 脚本,防止下次重启之后vDisk文件无法启动。
+
随后拷贝到U盘,改后缀名为 .vtoy 然后用 Ventoy 启动即可。
+Done.
+ +前言 本文记录常用虚拟化平台的使用与操作,包括Vmware,Hypr-v,QEMU等等。
+Vmware最新版本对个人已经免费,不需要再寻找激活码;
+由于博通官网下载Vmware需要登录账号,这里给出第三方下载站链接:techspot
+前期准备
+开始安装
+C:\Users\<你的用户名>\Documents\Virtual Machines\<虚拟机名称>\下.| 硬件 | 推荐配置 / 注意事项 |
|---|---|
| CPU 核心数 | 2 或更多 |
| 内存 | 至少 4 GB,若要流畅用 GNOME 桌面建议 8 GB |
| 显示适配 | 开启 3D 加速(如果 VMware 支持) |
| 硬盘控制器类型 | 通常 VMware 默认就行,SATA/SCSI,一般 Ubuntu 支持都不错 |
| 网卡 | 使用 NAT 或桥接,根据是否要虚拟机直接在局域网中可访问来定 |
安装这些工具能增强体验,例如鼠标整合、屏幕分辨率自动调整、剪贴板共享等等。
+Ubuntu 的方式通常是用 open-vm-tools 包:
sudo apt update
+sudo apt install open-vm-tools-desktop
+sudo reboot
+
+Hyper-V 是微软内建的虚拟化平台(native hypervisor)。开启后,它会占用硬件虚拟化特性(Intel VT-x / AMD-V),这可能会和 VMware、VirtualBox 等第三方虚拟化软件冲突。
+Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Hyper-V -All
+
+DISM /Online /Enable-Feature /All /FeatureName:Microsoft-Hyper-V
+
+控制面板 → 程序和功能 → 启用或关闭 Windows 功能中勾选 “Hyper-V”、 “Hyper-V 平台”、 “Hyper-V 管理工具” 等相关项目,然后按提示操作。Disable-WindowsOptionalFeature -Online -FeatureName Microsoft-Hyper-V-All
+
+DISM /Online /Disable-Feature:Microsoft-Hyper-V
+
+bcdedit /set hypervisorlaunchtype off
+
+若要恢复加载,则:
+bcdedit /set hypervisorlaunchtype auto
+
+下面是几个典型的场景和命令:
+bcdedit /set hypervisorlaunchtype off
+
+然后重启 Windows,就能让这些软件正常启动虚拟机。要还原 Hyper-V,改为 auto 或 on:
bcdedit /set hypervisorlaunchtype auto
+
+Disable-WindowsOptionalFeature -Online -FeatureName Microsoft-Hyper-V-All
+
+或者用 DISM:
+DISM /Online /Disable-Feature:Microsoft-Hyper-V
+
+msinfo32.exe(系统信息)看 “Hyper-V Requirements” 部分,或者在命令提示符/PowerShell 用 systeminfo 查看是否显示 “Hypervisor has been detected” 之类信息。控制面板 → 程序 → 启用或关闭 Windows 功能QEMU安装的系统默认在此位置下,可以使用Root用户将其复制到其他位置并备份:
+[root@dos:/var/lib/libvirt/images]ls
+ubuntu24.04-2.qcow2
+
+QEMU默认使用qcow2格式,几乎可以转换为所有其他虚拟机格式;我们可以使用qemu-img(QEMU 提供的镜像管理工具)来创建、转换、检查、调整虚拟机磁盘镜像。
基本语法:
+qemu-img [command] [options] filename
+
+镜像格式转换命令大全
+qemu-img convert -f <源格式> -O <目标格式> <源文件> <目标文件>
常见虚拟机平台格式:
+| 平台/软件 | 格式 | 示例扩展名 |
|---|---|---|
| QEMU/KVM | qcow2 | .qcow2 |
| VirtualBox | vdi | .vdi |
| VMware | vmdk | .vmdk |
| Microsoft Hyper-V | vhd/vhdx | .vhd / .vhdx |
| Xen | raw | .img |
raw ↔ qcow2# raw → qcow2
+qemu-img convert -f raw -O qcow2 disk.img disk.qcow2
+
+# qcow2 → raw
+qemu-img convert -f qcow2 -O raw disk.qcow2 disk.img
+
+qcow2 ↔ vdi (VirtualBox)# qcow2 → vdi
+qemu-img convert -f qcow2 -O vdi disk.qcow2 disk.vdi
+
+# vdi → qcow2
+qemu-img convert -f vdi -O qcow2 disk.vdi disk.qcow2
+
+qcow2 ↔ vmdk (VMware)# qcow2 → vmdk
+qemu-img convert -f qcow2 -O vmdk disk.qcow2 disk.vmdk
+
+# vmdk → qcow2
+qemu-img convert -f vmdk -O qcow2 disk.vmdk disk.qcow2
+
+qcow2 ↔ vhd/vhdx (Hyper-V)# qcow2 → vhdx
+qemu-img convert -f qcow2 -O vhdx disk.qcow2 disk.vhdx
+
+# vhdx → qcow2
+qemu-img convert -f vhdx -O qcow2 disk.vhdx disk.qcow2
+
+raw ↔ vdi/vmdk/vhdx# raw → vdi
+qemu-img convert -f raw -O vdi disk.img disk.vdi
+
+# raw → vmdk
+qemu-img convert -f raw -O vmdk disk.img disk.vmdk
+
+# raw → vhdx
+qemu-img convert -f raw -O vhdx disk.img disk.vhdx
+
+virsh domblklist <虚拟机名字>
+Target Source
+vda /var/lib/libvirt/images/ubuntu-24-04.qcow2
+
+qemu-img resize /var/lib/libvirt/images/ubuntu-24-04.qcow2 +20G
+
+lsblk
+
+sudo nix-env -iA nixos.cloud-utils # 提供 growpart
+
+sudo growpart /dev/vda 1
+
+ext4:
+sudo resize2fs /dev/vda1
+
+xfs:
+sudo xfs_growfs /
+
+有时候我们需要备份QEMU的镜像,但是镜像大小非常庞大,可以对其进行压缩。
+首先在虚拟机里(以Ubuntu为例)执行:
+sudo apt clean
+sudo rm -rf /var/log/*log /var/log/journal/* # 清理日志
+
+然后填充空闲空间:
+sudo dd if=/dev/zero of=/zero.fill bs=1M || true
+sudo sync
+sudo rm -f /zero.fill
+
+随后关闭虚拟机,在宿主机上使用 qemu-img 压缩:
qemu-img convert -O qcow2 ubuntu24.04-2.qcow2 ubuntu24.04-2-compressed.qcow2
+
+可选:加上 -c 开启压缩:
qemu-img convert -O qcow2 -c ubuntu24.04-2.qcow2 ubuntu24.04-2-compressed.qcow2
+
+++不要直接删除原始文件,先确认新文件能正常启动。如果你的 qcow2 镜像是直接被写满了(比如里面确实存了很多真实数据),那即使压缩也不会小太多。如果镜像内部用了 LVM,还可以在 LVM 里使用sudo fstrim -av进行fstrim.
+
Done.
+ +用电子罗盘,转赛博核桃,勘电磁风水,寻网络龙脉
+++一个人应该能够给孩子换尿布、计划一次侵略行动、杀猪、驾驶飞船、设计建筑物、写诗、做会计账目、砌墙、接合断骨、照顾临终的人、执行命令、下达命令、与人合作、独立行动、解方程式、分析一个新问题、施肥、编程、做一餐美味的饭、高效地战斗、勇敢地死去。专业化是为昆虫准备的。 ——罗伯特·海因莱恩
+
有事请联系 admin@dich.bid
+ +前言 自安卓系统诞生以来,root 一直是玩机的必备过程。时至今日,在安卓定制系统日益完善的情况下,能 root 的机型越来越少,本文以小米手机为例,介绍 root 的具体方法。
+这涉及安卓的权限系统。Andoird 系统是基于 Linux 内核的,Linux中的root用户为超级用户,root 权限则为系统的最高权限,与 Windows 的 system 权限相当(比 administer 还高)。日常使用中我们可以发现一般软件权限需要经过用户同意,即每次安装前出现的各种请求弹窗。我们看似可以做到许多事情,但有些地方比如安卓的根目录没有root就无法查看。
所谓 Root 也就是使手机获得超级管理员的权限,但是出于种种原因,厂商默认不提供超级管理员的权限,因此,root的本质就是一个提权的过程。
国内定制的安卓系统充满着云控,反诈以及各种广告,预装软件,这种系统实在为极客们所不容;而当我们具备了 root 权限后,就可以实现许多功能,例如屏蔽广告,虚拟定位,安装 Google 框架和软件,满血运行CPU,删除系统自带软件等等。
+某种意义上不能root的手机相当于只有使用权而无所有权,不能完全控制自己的数据。
+我可以不要但你厂商不能不给。
+++云控:一般指为了计划性报废而特地远程操控使用户的手机变的卡顿,加快换机;也有另一层含义:在UP主测试手机时调整设置使其跑分虚高而用户到手的手机分数远不如测试的时候的情况。
+
++反诈:一般指厂商与网络安全部门合作的后门或漏洞,可以监控用户行为,例如某 +“其他”品牌手机系统的webview级别的网址拦截;
+
++广告:一般指系统自带的弹窗广告,自带系统应用中的广告和“负一屏”中的广告。
+
在 2023 年的今天,能 root 的机型还是比较少。各品牌手机root情况汇总
+| 品牌 / 机型 | BL 解锁情况 | 等待时长 | 支持回锁 | Root/越狱 能力 |
|---|---|---|---|---|
| OnePlus | ✅ 支持 | 秒解 | ✅ 支持 | ✅ 容易 root |
| Google (Pixel) | ✅ 支持 | 秒解 | ✅ 支持 | ✅ 容易 root |
| Nothing Phone | ℹ️ 社区支持 | — | — | ✅ 社区方法多 |
| Motorola | ✅ 支持 | 官方发解锁码 | ⚠️ 部分 | ✅ 社区方法多 |
| Xiaomi/Redmi/POCO | ⚠️ 支持 | ~7–14 天 | ⏹ 部分 | ✅ 可 root(需等待) |
| Lenovo | ✅ 支持 | 秒解 | ⚠️ 部分 | ✅ 容易 root |
| Sony | ⚠️ 支持 | — | ⚠️ 部分 | ✅ 海外版易 root |
| OPPO / Realme | ⚠️ 支持 | — | — | ❌ 部分型号难 root |
| Vivo / iQOO | ⚠️ 支持 | — | — | ❌ 部分型号难 root |
| Huawei | ❌ 不支持 | — | — | ❌ 基本不可 root |
| Honor | ❌ 不支持 | — | — | ⚠️ 少数型号有社区支持 |
| ASUS | ❌ 不支持 | — | ❌ | ❌ 不可 root |
| Black Shark | ❌ 不支持 | — | — | ❌ 不可 root |
| LG | ❌ 不支持 | — | ✅ 支持 | ⚠️ 旧机型可能可 root |
| Meizu | ❌ 不支持 | — | — | ⚠️ 部分机型有 root 方法 |
| Samsung | ⚠️ 支持 | — | — | ❌ 解锁后 Knox 熔断,Pay 功能被禁用 |
| Apple iPhone | ❌ 不支持 | — | — | ✅ iPhone 10 前可越狱 |
刷机有风险,root 需谨慎!刷机前要了解相应的厂商,考虑保修和变砖的问题!
可以选择官方原版,官改版,海外版和类原生版。官方原版镜像一般用来救砖;官改版在一些方面例如性能更为强大;海外版本如EEA(欧盟版)为符合法规对隐私保护更好且广告更少;而类原生版是在AOSP的基础上进行简单修改,最为纯净原生。
需要注意这些rom的搜索往往使用的海外名,得先搜索你所对应机型的海外名称/代号。
+++需要注意的是刷类原生系统较之其他系统可能会有如下问题;如果你只需要root,推荐使用原厂系统。
+
首先我们要了解安卓系统的分区和启动。安卓的分区包括:
+recovery 分区,类似PC端的PE环境,手机上的恢复出厂设置即为从 recovery 恢复;
cache 分区,保存系统最常访问的数据和应用程序。 擦除这个分区,不会影响个人数据,只是删除了这个分区中已经保存的缓存内容;
boot 分区,类似PC端的MBR分区,用来引导系统启动,擦除后手机会卡在开机 logo 的界面;
system 分区,包括操作系统与软件,vendor 定制文件与库文件等等,擦除后会卡在开机的动画界面;
data 分区,存放用户数据和系统设置,擦除后不影响系统的运行。
++除了以上5大分区外,手机启动阶段还存在名为 bootloader 的程序,通常位于设备的专用引导区域(如boot ROM或firmware分区的一部分),与 PC 端的 BIOS 类似,被称为 fastboot 模式,厂商一般会将其锁定,要刷机的话必须解开它。
+
++早些年间,存在大量一键 root,kingroot 之类的软件,可以直接刷写 root 包,获得 root 权限,但成功率不高,且有植入木马之嫌。
+
因此,现在主流的刷机步骤为
+备份手机数据,即备份Data分区(可使用Neobackup或系统自带),字库/基带/官方固件,桌面样式截图以及该机器的官方原厂包;
打开机器上的允许USB调试;
解开 bootloader,俗称解BL锁. BL锁原理参考
下载要刷的第三方系统包和原厂系统包并提取以上两个包中的 boot.img 和 recovery.img 文件;
+将机器与PC等设备连接,并进入 bootloader;
刷入第三方 recovery,比如大名鼎鼎的 TWRP,或者对应新系统的recovery.img;
进入 recovery 模式,清空原系统数据并刷入新系统Zip包,随后重启,即可进入新系统。
+主流的root步骤:
+刷入 Magisk (面具)zip包,随后重启进入桌面,安装 Magisk(apk),在其中选择直接安装;fastboot flash boot apatch_patched-boot.img,重启即可。常用root方案
+ +| 命令 | 说明 |
|---|---|
adb devices | 列出 adb 设备 |
adb reboot | 重启设备 |
adb reboot bootloader | 重启到 fastboot 模式 |
adb reboot recovery | 重启到 recovery 模式 |
adb reboot edl | 重启到 edl 模式 |
adb sideload <要刷写的文件路径> | 刷写模块,如 Magisk |
使用adb备份分区
+adb shell ls -l /dev/block/bootdevice/by-name
+
+可以看到有很多分区,例如这些
+...
+lrwxrwxrwx 1 root root 15 1970-12-24 11:30 frp -> /dev/block/sda5
+lrwxrwxrwx 1 root root 16 1970-12-24 11:30 fsc -> /dev/block/sdf13
+lrwxrwxrwx 1 root root 16 1970-12-24 11:30 fsg -> /dev/block/sdf12
+lrwxrwxrwx 1 root root 15 1970-12-24 11:30 hyp_a -> /dev/block/sde5
+lrwxrwxrwx 1 root root 16 1970-12-24 11:30 hyp_b -> /dev/block/sde40
+...
+
+随后使用root备份分区到手机上
+adb root
+
+adb shell "dd if=/dev/block/sda2 of=/sdcard/partition_backup/persist.img"
+
+然后可以上传到PC端
+adb pull /sdcard/partition_backup/ ./backup/
+
+| 命令 | 说明 |
|---|---|
fastboot devices | 列出 fastboot 设备 |
fastboot reboot | 重启设备 |
fastboot reboot-bootloader | 重启到 fastboot 模式 |
fastboot flash <分区名称> <镜像文件名> | 刷写分区 |
fastboot oem reboot-<模式名称> | 重启到相应模式 |
fastboot oem device-info | 查看解锁状态 |
++以 Poco F2 这款手机为例,
+
首先我们进入手机设置界面,进入“我的设备”,在“全部参数”中找到“ MIUI 版本”,连续点击后开启开发者模式,随后在“更多设置”中开启 USB 调试, USB安装 功能。
+然后我们进入小米官网 ,下载官方解锁工具,需要登陆小米账号并等待7天,随后即可解锁。
+解锁完成后在MiFirm网 中下载对应的 TWRP 版本。
+随后用数据线连接手机,用其中的一键刷写刷入 TWRP;随后下载你要刷的系统的 rom 包,下载时注意一并下载 boot.img 文件,作为 Magisk 的修补用。然后下载 Magisk 包,与 rom 一起存入TF卡或者U盘中。
+++注意,由于本机型为新型AB分区因此如果刷机失败,需要下载原厂包用以恢复AB分区,否则无法启动和安装rom。
+
进入 recovery 模式,首先我们清除Data、Cache两个分区,俗称“双清”,随后在高级清除选项中清除 Data、Cache、Dalvik Cache 和 System 分区,俗称“四清”。
清除完成后即可开始刷机。将 TF 卡或者U盘插入手机,在“安装”中选择 rom 包,右滑确认刷机;随后如法炮制,刷入 magisk.zip 包,不然会卡在开机 logo 界面,俗称“卡米”。
+刷完之后重启,则会进入安装界面。注意:如果刷的是海外版的包,千万不能联网安装,否则会失败且变为国内版。
+此刻我们将下载好的 boot.img 文件复制到手机上,打开 Magisk 软件,在其中选择修补一个文件,选中 boot.img,修复完成后可以看到超级用户一栏可以使用了,说明 root 完成。
+++以一加(oneplus)为例:
+
打开开发者模式并开启USB调试,连接到提前装好ADB/Fastboot驱动的电脑;
+随后进入fastboot模式(adb reboot bootloader),执行fastboot oem unlock或者fastboot flashing unlock,查看fastboot oem device-info,若为Device unlocked: true表示已成功解锁。
随后刷入新系统的recovery.img,使用命令fastboot flash recovery xxx.img;四清操作可以用fastboot erase data / fastboot erase cache / fastboot erase system / fastboot erase metadata 代替。
随后进入新系统的recovery,使用命令fastboot reboot recovery,在其中adb sideload xxx.zip,即为刷入新系统的全量包。
随后 adb reboot 即可进入新系统。
++如果你不想安装TWRP也可以直接安装要刷的系统的recovery,一般放在系统zip包的中,如果没有则需要手动解包payload.bin,可以安装payload-dumper-go并在解压出来的系统文件夹中使用
+payload-dumper-go payload.bin,随后会将所有.img后缀的文件放在文件夹中。
在 Root 管理器中安装 Zygisk-Lsposed 模块,即可使用 Lsposed,在 Lsposed 中可以安装 HMA, Amarok ,QAuxiliary 模块,并配合 MMRL 等软件等等。
+++免 Root 的平替方法,目前这一套流程也很成熟了:利用 ADB 权限的 Shizuku;利用 Device Owner 权限的 Dhizuku等等。
+
++ +常用模块
+
| 厂商 | 系统 / 子品牌 | 演变历史及时间点 |
|---|---|---|
| Xiaomi | MIUI → 澎湃OS(HyperOS / Surge OS) | 2010 年推出 MIUI,2023 年 10 月 17 日官方宣布替代 MIUI 的 HyperOS(中文名“澎湃OS”),2023 年 10 月 26 日随 Xiaomi 14 系列一起发布,2024 年起全面替代 MIUI |
| Huawei | EMUI → HarmonyOS | 2012 年采用 EMUI,2021 年宣布推出基于微内核的鸿蒙 HarmonyOS,新机逐步切换。 |
| OPPO | ColorOS | 2013 年推出 ColorOS,2020 年对版本号体系调整至与 Android 主版本同步(例如从 7 跳到 11),之后持续 UI 与功能迭代。 |
| Realme | Realme UI | 2019 年从 ColorOS 分支出 Realme UI,此后持续独立更新、优化(未查到主要时间节点)。 |
| Vivo / iQOO | Funtouch OS → OriginOS (+ Ocean/Pux 系列) | 2012 年左右推出 Funtouch OS,2020 年推出 OriginOS;后续版本如 OriginOS Ocean、Pux 迭代 UI 核心。 |
| OnePlus | HydrogenOS (中国) → OxygenOS (海外) → 合并后 OP OS? | 2014 年中国区发布 HydrogenOS,2015 年海外推 OxygenOS;2021 年底与 OPPO 合并,代码库统一(国内使用 ColorOS,全球继续用 OxygenOS),但官方未明确推出 "OP OS" 这一新名。 |
| Samsung | TouchWiz → Samsung Experience → One UI (+ One UI Core) | 2009 年推出 TouchWiz,2016 年改名为 Samsung Experience,2018 年重塑为 One UI,2020 年开始细化为标准与精简版 One UI Core。 |
| Asus | ZenUI | 2014 年推出 ZenUI,后续多年持续在视觉与功能上迭代。 |
| Motorola | MotoBlur → My UX | 2009 年推出 MotoBlur,2020 年推出基于原生 Android 的 My UX。 |
| Sony | Xperia UI | 自 Xperia 系列以来,Sony 一直使用 Xperia UI,接近原生 Android,逐步做微调。 |
| 文件名 | 说明与功能 |
|---|---|
| abl.img | Android Boot Loader(第二阶段引导加载器),负责从 XBL 启动 Android kernel。 |
| aop.img / aop_config.img | Always-On Processor:负责处理低功耗任务,辅助系统唤醒等操作。Config 存配置。 |
| bluetooth.img | 蓝牙固件,负责设备蓝牙功能的驱动与协议栈加载。 |
| boot.img / init_boot.img | 启动分区:包含 kernel(init_boot 从 Android 13+ 将 ramdisk 拆出) |
| cpucp.img / cpucp_dtb.img | CPU Control Processor:处理内核 CPU 调度或控制器,DTB 部分存设备树信息。 |
| devcfg.img | Device Configuration:设备硬件配置,例如 I/O 设置等参数。 |
| dsp.img | Digital Signal Processor 固件,处理音频等信号处理任务。 |
| dtbo.img | 设备树覆盖层(Device Tree Blob Overlay),定义硬件特定参数。 |
| engineering_cdt.img | 工程测试用 partition,常含硬件校正或测试数据。 |
| featenabler.img | Feature Enabler:启用或关闭厂商定制功能或隐藏功能的标记配置区。 |
| imagefv.img | Image Feature Version:存储镜像版本控制或签名校验信息。 |
| hyp.img | Hypervisor:虚拟化层固件,用于安全隔离或多系统调度。 |
| keymaster.img | 安全模块 Keymaster:处理加密密钥、安全认证等功能。 |
| modem.img | 基带固件,控制数据通信(LTE/5G/Wi-Fi/Bluetooth)等。 |
| odm.img | OEM 驱动与功能,硬件相关组件:摄像头、传感器等逻辑支持层。 |
| oplus_sec.img / oplusstanvbk.img | 厂商定制安全配置或分区(OnePlus 专用)。 |
| product.img | OEM 或 carrier 定制应用和配置,Android 9+ 新增分区 |
| qupfw.img | Qualcomm UFS(或其他闪存)媒体驱动固件,通常用于闪存控制器。 |
| recovery.img | Recovery 启动镜像,用于刷机、恢复环境。 |
| shrm.img | Secure Hardware Resource Management:安全资源管理模块。 |
| splash.img | 启动动画或厂商 Logo 展示图片。 |
| system.img / system_ext.img / system_dlkm.img | 系统分区:包含 Android 框架、扩展库(dlkm 存模块) |
| tz.img | TrustZone 安全环境固件(QSEE / TEE)。 |
| uefi.img / uefisecapp.img | UEFI 启动环境及安全应用层,用于兼容启动和安全验证。 |
| vbmeta.img / vbmeta_system.img / vbmeta_vendor.img | Verified Boot 签名校验 metadata,确保完整性安全。 |
| vendor.img / vendor_boot.img / vendor_dlkm.img | 厂商驱动层及扩展,vendor_boot 是引导层,dlkm 是模块。 |
| xbl.img / xbl_config.img / xbl_ramdump.img | Qualcomm XBL(eXtensible Boot Loader)引导,加载 ABL 等;ramdump 用于调试。 |
前言 由于 AppleTV 的高昂的售价和普通电视盒子广告的泛滥,一台开源、多功能的原生安卓电视盒子逐渐成为智能家居的必备神器。出于对 IPTV、YouTube 和家庭影院等需求,以及对一面赏心悦目电视墙的期待,这里分享 Android TV (以下简称ATV)安装的一些要点。
+X86还是Arm?两者之间各有优点,截止到今天各种Arm电视盒子已经非常成熟,价格便宜,也可以使用运营商的电视盒子进行刷机,性能并不会太弱;而X86平台往往价格偏贵,且驱动不全,解码性能和功能适配没有和电视生态联系紧密,因此建议首选Arm平台.
+本文以s905l3a盒子为示例,截止目前平均价格在60rmb左右,非常具有性价比。
+| 项目 | 规格说明 |
|---|---|
| CPU 架构 | 四核 ARM Cortex-A53 (64-bit) |
| 主频 | ~1.8 GHz |
| 制程工艺 | 12 nm |
| GPU | Mali-G31 MP2,约 850 MHz,20.8 GFLOPS |
| 视频解码 | H.265 4Kp75 (10-bit), H.264 4Kp30 |
| 视频编码 | H.264/H.265 1080p60 |
| 最大显示输出 | 4K @ 75fps |
| 内存支持 | 支持 DDR3, DDR4-2666, LPDDR4-3200;设备常见 2 GB DDR4 |
| 存储 | 常见 8 GB eMMC5.1 |
| 接口支持 | USB2.0/3.0, HDMI 2.0b/2.1 |
| 网络支持 | 千兆 MAC (常见盒子为 10/100), Wi-Fi, BT4.1/5.0 |
| 发布时间/制程 | Q3 2022,12 nm |
++如果预算充足,也可以选择s905x3,s905x4,以及rk3528等等芯片的盒子。如果有旧手机,也可以改装为电视盒子,比如骁龙865盒子,性能非常强大。
+
无论是运营商自带的电视盒子还是各种所谓的“无广告”电视盒子,往往都基于以下两种系统,且要小心一些所谓的“无广告”电视盒子或者外贸盒子,它们往往配置低,性价比不高且还是有内置付费项目,甚至有一些还会偷偷跑PCDN。因此,建议买到手之后自行刷写固件。
+| 特性 | Android-x86 | Android TV |
|---|---|---|
| 目标用户 | 面向 PC 用户,将 Android 运行在 x86/x86_64 设备上。 | 面向电视和机顶盒用户,优化用于遥控器或语音操作。 |
| 适配设备 | 传统 PC、笔记本、平板电脑等 x86 架构设备。 | 智能电视、电视盒子等 ARM 或特定芯片架构设备。 |
| 界面设计 | 和标准 Android 类似,为触摸屏和鼠标键盘优化。 | 专为大屏设计,使用 Leanback UI,适配遥控器操作。 |
| Google 服务 | 默认不包含 Google 服务,需要用户手动安装。 | 官方版本内置 Google 服务(例如 Play Store、Assistant)。 |
| 开机启动器 | 使用标准 Android 桌面启动器(Launcher3)。 | 使用电视优化的启动器(Leanback Launcher)。 |
| 架构支持 | 专注于 x86/x86_64,但支持 ARM 仿真(通过 Houdini)。 | 主要支持 ARM/ARM64 架构,有限支持 x86。 |
| 硬件支持 | 需要额外优化,部分硬件(如 GPU 驱动)可能无法正常工作。 | 深度集成硬件,默认支持电视硬件(如 HDMI CEC、音频输出)。 |
| 应用市场 | 默认不内置 Google Play,需要手动安装 Aurora Store 等替代方案。 | 默认集成 Google Play 商店,提供大屏优化的应用程序。 |
| 遥控器支持 | 不适配遥控器,主要使用鼠标键盘操作。 | 专为遥控器优化,支持按键导航和语音输入。 |
| 开源贡献 | 由社区维护,支持各种自定义和实验功能。 | 由 Google 官方主导,OEM 厂商提供硬件优化支持。 |
++Android-x86 的安装类似windows;Android TV安装类似 Android手机,通过刷分区或TWRP卡刷安装。
+
++Tosathony 制作的 Android TV x86 是一个由社区成员制作的定制化 Android TV 版本,针对 Android TV 的大屏界面 和 遥控器操作 进行特别优化,但某些硬件(如 Wi-Fi、GPU、音频设备等)的驱动可能不兼容或需要额外的配置,本文不再说明Android TV x86的安装与使用。
+
刷写固件可以买一个“刷机神器”(HDMI短接器)和一个双公头的USB线,即可使用usb-burning-tool来进行刷机,推荐使用2.2.4版本.
+安装软件有很多方法,可以使用U盘将apk安装包拷入,也可以使用localsend将apk安装包通过内网传输过去。这里介绍一种通过ADB安装软件的方法。
+首先我们在设置中找到“设置”>“设备首选项”>“关于”,然后在“构建”上点击几次以解锁开发者模式,随后开启USB调试开关。
随后在设置 > 设备首选项 > 关于 > 状态中找到并记下IP 地址,然后用ADB连接上去,这里使用命令adb connect <IP 地址>:<端口> ,随后在ATV端授权连接,例如:
❯ adb connect 192.168.1.666:9527
+
+connected to 192.168.1.666:9527
+
+❯ adb devices
+
+xxxxxxxxx sideload
+
+adb install <path to android app.apk>将要安装的软件包上传,也可以将文件拖到命令提示符窗口上以复制其路径,回车确认。一些 ADB 常用命令:
+adb reboot #将重启 Android 设备。
+
+adb reboot recovery #将设备重新启动到恢复模式。
+
+adb push <local> <remote> #将文件从您的 PC 复制到您的 Android 设备。
+
+adb shell wm density <dpi> #改变显示器的像素密度。
+
+adb kill server #切断 PC 和 Android TV 之间的连接。
+
+要安装的软件
+TVBox:前猫影视,可自行添加源,包括电影电视剧等等,选择 armeabi-generic-java.apk
+PPSSPP:PSP模拟器,支持高清修复游戏,选择 APK for Android
+BBLL:第三方开源哔哩哔哩客户端,适配TV界面,不需要额外VIP
+酷9TV:经典IPTV播放器,功能丰富,可导入IPTV源使用
+VLC:老牌开源音视频播放器,支持远程和串流功能
+Kodi:开源的跨平台多功能媒体播放器和数字媒体娱乐中心,非常强大
+TV-Bro:适用与安卓TV的浏览器,经过了遥控器优化设计,可以作为网页播放器
+MaterialFiles:又名质感文件,优秀的开源文件管理器
+Localsend:经典内网互传工具,可以通过它传输apk安装包或者视频到TV上
+ATV Launcher:平铺风格的安卓启动器,可以形成海报墙效果
+++注意s905l3a为32位架构,需要下载带armv7a的软件
+
安装所需的软件包后我们可以删除自带的牛马软件或者不需要的软件,比如我们要安装ATV,就可以删除当贝桌面。
+adb shell进入shell,随后使用命令pm list packages列出所有软件包;pm list packages -s 列出系统软件包
+pm list packages -3 列出第三方软件包
+
+adb shell dumpsys activity activities | grep mResumedActivity
+
+获取当前前台应用的包名,随后再禁用或者删除.
+pm disable-user --user 0 com.dangbei1.tvlauncher
+
+禁用软件,确认没有问题之后再用
+pm uninstall -k --user 0 com.dangbei1.tvlauncher
+
+删除;
+adb shell pm path org.videolan.vlc
+
+package:/data/app/~~hY2Y0_PdaDlasfVwkUNcoQ==/org.videolan.vlc-WnNhCJLQUJdZYYzUxzBNBA==/base.apk
+
+获取到安装路径,随后将apk包拿走就可以:
+adb pull /data/app/~~hY2Y0_PdaDlasfVwkUNcoQ==/org.videolan.vlc-WnNhCJLQUJdZYYzUxzBNBA==/base.apk ./Downloads/
+
+# 确定分区对应关系
+ls -l /dev/block
+ls -l /dev/block/platform
+cat /proc/mounts
+
+
+# 导出到 /sdcard/
+dd if=/dev/block/boot of=/sdcard/boot.img
+dd if=/dev/block/recovery of=/sdcard/recovery.img
+dd if=/dev/block/system of=/sdcard/system.img
+dd if=/dev/block/vendor of=/sdcard/vendor.img
+dd if=/dev/block/product of=/sdcard/product.img
+dd if=/dev/block/odm of=/sdcard/odm.img
+
+# 拉去到PC
+adb pull /sdcard/boot.img
+adb pull /sdcard/recovery.img
+adb pull /sdcard/system.img
+adb pull /sdcard/vendor.img
+adb pull /sdcard/product.img
+adb pull /sdcard/odm.img
+
+adb shell pm disable-user --user 0 com.google.android.tvlauncher
+adb shell pm disable-user --user 0 com.google.android.tungsten.setupwraith
+
+命令禁用原来的默认桌面。随后重启盒子即可看到海报墙效果,如果ATV桌面没有开机自启动,可以使用Launch on Boot工具。
+最终效果:
+
前言 Arch linux是一个轻量、灵活、滚动更新的 Linux 发行版,衍生了诸多优秀的桌面端linux。其官方Wiki更是被称为技术界的“武林秘籍”;这里介绍其安装与使用。
+一般而言有以下几种安装方法:
+前两种方法较为繁琐,这里说明第三种方法:常见的Arch发行版有Garuda,Cachyos以及EndeavourOS等等。
+ +安装方法同ubuntu一样,是基于Calamares的图形化界面安装。一般步骤为选择语言(American English)--选择键盘/时区(默认/shanghai)--选择分区(xfs抹除全盘,可选全盘加密)--选择桌面环境(Gnome或KDE)--确认安装。
随后安装常用开源软件(KDE环境省略file和wayland)
+# gui
+
+paru -S floorp-bin keepassxc qemu-full virt-manager materialgram-bin legcord-bin onlyoffice-bin localsend-bin kazumi-bin foliate vlc krita qtscrcpy strawberry oculante obs-studio
+
+# tui
+
+paru -S neovim yazi lazygit btop zellij termshark
+
+# cli
+
+paru -S alacritty fish fastfetch tealdeer expac fish-autopair fish-pure-prompt fisher onefetch starship atuin bat fzf fd ripgrep eza tree android-tools payload-dumper-go-bin nexttrace-bin syncthing aria2
+
+
+# file
+
+paru -S gvfs gvfs-mtp gvfs-afc gvfs-nfs nemo
+
+# zip
+
+paru -S peazip
+
+# Type
+
+paru -S fcitx5-configtool fcitx5-chinese-addons fcitx5-skin-material fcitx5-im fcitx5-rime
+
+# Blog
+
+paru -S zola npm pnpm just go
+
+# ttf
+
+paru -S ttf-jetbrains-mono-nerd
+
+# Wayland
+
+paru -S hyprland waybar wofi network-manager-applet swww wl-gammarelay-rs brightnessctl easyeffects wireplumber pipewire blueman wl-clipboard-rs swaync swayosd swappy grim wlogout hyprlock hyprpolkitagent
+
+| 分类 | 软件列表 |
|---|---|
| 窗口管理器 | hyprland |
| 状态栏 | waybar |
| 启动器 | wofi |
| 网络 | network-manager-applet |
| 蓝牙 | blueman |
| 音频 | pipewire, wireplumber |
| 亮度 | brightnessctl, wl-gammarelay-rs |
| 剪贴板 | wl-clipboard-rs,wl-clip-persist |
| 通知 | swaync,swayosd |
| 截图 | grim, swappy |
| 壁纸管理 | swww |
| Polkit 授权代理 | hyprpolkitagent |
| 锁屏/开始菜单 | hyprlock, wlogout |
| 文件管理 | gvfs, gvfs-mtp, gvfs-afc, gvfs-nfs, nemo |
安装完毕后我们开始配置输入法与字体:
+输入法我们采用雾凇拼音,即前面我们安装的fcitx5系列软件包的一个输入方案,这里我们使用自动部署脚本:
+# step1: 克隆/下载 latest 最新的稳定版到本地
+git clone --depth=1 https://github.com/Mark24Code/rime-auto-deploy.git --branch latest
+# step2: 进入项目目录
+cd rime-auto-deploy
+# step3: 执行部署脚本
+./installer.rb
+
+选择部署fcitx5即可,随后在设置的Input Method中Add Input Method ,选择Rime,随后默认按Ctrl+Space即可切换中文。
+字体的配置在Linux之旅(七):系统与终端字体设置这一期说过,这里不再赘述。缺少的字体可以通过paru下载或者到喵闪字库下载ttf并安装。
+安装完毕后可以看到KDE的界面较为简陋,这里给出笔者的美化配置:
+- Color:Breeze Dark
+- Application Style:Breeze
+- Plasma Style:Sweet
+- Window Decorations:Edna
+- Icons:BeautySolar
+- Cursors:Afterglow Cursors
+- Splash Screen:None
+
+随后设置壁纸,这里给出了笔者收藏的壁纸。
+设置完成后将Dock栏的Status全部隐藏,删除间隔与空隙,删除时间,更改Memu图标,随后固定常用软件到其上。
+随后在Dock栏下新建一个空白栏,结构为数字时钟加两个空白,字体为JetBrains Mono,24小时ISO格式。最终效果如下:
+
将需要的数据迁移到Home目录下,对笔者来说是用来同步的Data文件夹以及Git工作文件夹。随后Add to Places将其固定到侧边栏,开启隐藏文件可见,将View mode改为Detail。最终效果如下:
+
创建配置目录:mkdir -p ~/.config/fastfetch
+创建配置文件:touch ~/.config/fastfetch/config.jsonc
+编辑该文件以添加你的自定义选项
+
+设置GFS:参考乱七八糟:GFS项目考量笔记 。
+设置Keepassxc/Vscodium/Electerm:导入备份好的配置文件。
+设置Matrix/Telegram:登录并在另一台设备上验证。
+设置浏览器:导入书签备份文件(有图标);定制工具栏,下载扩展插件,包括:
+Dark Reader(暗黑模式)
+kiss-translator(翻译工具)
+uBlock Origin(广告拦截)
+ClearURLs(去跟踪链接)
+KeePassXC-Browser(链接Keepass)
+BookmarkHub(书签同步)
+BewlyBewly(B站美化)
+V2EX Polish(V站美化)
+
+如果Grub引导菜单中没有windows选项,可以通过以下方法添加:
+sudo pacman -S os-prober
+sudo os-prober
+
+sudo nano /etc/default/grub
+# 确保 GRUB_DISABLE_OS_PROBER 设置为 false
+
+sudo grub-mkconfig -o /boot/grub/grub.cfg
+
+或者手动添加:
nano /etc/grub.d/40_custom
+
+#!/bin/sh
+exec tail -n +3 $0
+# This file provides an easy way to add custom menu entries. Simply type the
+# menu entries you want to add after this comment. Be careful not to change
+# the 'exec tail' line above.
+menuentry "Windows 11 (Manual)" {
+ insmod part_gpt
+ insmod fat
+ insmod chain
+ set root='hd0,gpt1'
+ chainloader /EFI/Microsoft/Boot/bootmgfw.efi
+}
+
+前面我们已经安装了Qemu高性能虚拟机平台和virt-manager用来管理虚拟机的图形界面,随后配置virt-manager并安装Ubuntu-server:
+如果virt-manager报错无法找到Qemu,则:
+sudo systemctl start libvirtd
+sudo systemctl enable libvirtd
+
+sudo usermod -aG libvirt $(whoami)
+
+sudo virsh net-start default
+
+默认网络在系统启动时自动启动,可以执行:
+sudo virsh net-autostart default
+
+sudo chown $(whoami):libvirt /var/run/libvirt/libvirt-sock
+
+随后安装虚拟机,流程大概为选择镜像和系统类型--设置CPU/内存--设置空间大小--编辑配置项--开启UEFI引导和3D加速.
开启3D加速:
+<graphics type="spice">
+ <listen type="none"/>
+ <image compression="off"/>
+ <gl enable="yes" rendernode="/dev/dri/by-path/pci-0000:05:00.0-render"/>
+</graphics>
+
+
+<video>
+ <model type="virtio" heads="1" primary="yes">
+ <acceleration accel3d="yes"/>
+ </model>
+ <alias name="video0"/>
+ <address type="pci" domain="0x0000" bus="0x00" slot="0x01" function="0x0"/>
+</video>
+
+安装完成后即可使用electerm进行SSH连接,如果无法连接,可以将Tun模式开启的"strict_route"关闭。
+如果安装了多个linux内核,可以使用以下方法调整启动顺序:
+ls /boot/vmlinuz*
+
+GRUB_TOP_LEVEL="/boot/vmlinuz-linux-cachyos"
+
+需要注意,这种方法会关闭 GRUB 的“记住上次启动项”的功能。
+sudo grub-mkconfig -o /boot/grub/grub.cfg
+
+图形界面更改方法:
+可以使用grub-customizer来修改Grub,这里以ubuntu为例子:
+sudo add-apt-repository ppa:danielrichter2007/grub-customizer
+sudo apt update
+
+sudo apt install grub-customizer
+
+随后在grub-customizer中将要默认启动的选项放在首位即可。
+设置Syncthing开机自启动
+sudo systemctl enable --now syncthing@<username>.service
+
+设置Aria2开机自启动
+[Unit]
+Description=Aria2c - lightweight multi-protocol & multi-source command-line download utility
+After=network.target
+
+[Service]
+User=dich
+Group=dich
+WorkingDirectory=/home/dich
+Environment=HOME=/home/dich
+Environment=USER=dich
+ExecStart=/usr/bin/aria2c --conf-path=/home/dich/.config/aria2/aria2.conf
+Restart=always
+NoNewPrivileges=true
+PrivateTmp=true
+
+[Install]
+WantedBy=multi-user.target
+
+uname -r
+
+你只需要设置两个 sysctl 参数即可:
+sudo sysctl -w net.core.default_qdisc=fq
+sudo sysctl -w net.ipv4.tcp_congestion_control=bbr
+
+要让它们永久生效,把它们写入配置文件:
+sudo nano /etc/sysctl.d/99-bbr.conf
+
+加入以下内容:
+net.core.default_qdisc = fq
+net.ipv4.tcp_congestion_control = bbr
+
+然后重新加载配置:
+sudo sysctl --system
+
+sysctl net.ipv4.tcp_congestion_control
+
+应该输出:
+net.ipv4.tcp_congestion_control = bbr
+
+需要安装power-profiles-daemon
# 查看可用的电源配置文件(profiles)
+powerprofilesctl list
+
+# 查看当前正在使用的 profile
+powerprofilesctl get
+
+# 切换到“性能”模式
+sudo powerprofilesctl set performance
+
+# 切换到“平衡”模式
+sudo powerprofilesctl set balanced
+
+# 切换到“省电”模式
+sudo powerprofilesctl set power-saver
+
+Profile‑sync‑daemon
+将浏览器配置文件和缓存挂载到内存,退出时再写回磁盘:
+
+sudo pacman -S profile-sync-daemon
+systemctl --user enable --now psd.service
+
+Systemd‑oomd
+启用 systemd 自带的内存超载保护守护进程:
+
+sudo pacman -S systemd-oomd
+sudo systemctl enable --now systemd-oomd
+
+Bpftune
+加载 BPF 性能调优脚本(网络、I/O、调度等):
+
+sudo pacman -S bpftune
+sudo systemctl enable --now bpftune
+
+Ananicy‑Cpp
+根据预设规则给游戏、多媒体和后台任务打优先级标签:
+
+sudo pacman -S ananicy-cpp
+sudo systemctl enable --now ananicy-cpp
+
+更新系统:sudo pacman -Syu
+
+重新安装所有软件包:sudo pacman -Qq | sudo pacman -S -
+
+Reset keyrings:
+
+sudo rm -rf /etc/pacman.d/gnupg
+sudo pacman-key --init
+sudo pacman-key --populate archlinux
+
+移除数据库锁:sudo rm -f /var/lib/pacman/db.lck
+
+清理软件包缓存:sudo pacman -Sc (或 -Scc 完全清空)
+
+删除孤立软件包:sudo pacman -Rns $(pacman -Qtdq)
+
+Install Gaming packages:sudo pacman -S steam wine lutris dxvk
+
+排序镜像:
+
+sudo pacman -S reflector
+sudo reflector --latest 10 --sort rate --save /etc/pacman.d/mirrorlist
+
+更改 DNS 服务器:编辑 /etc/systemd/resolved.conf 中的 DNS=1.1.1.1 8.8.8.8,然后 sudo systemctl restart systemd-resolved
+
+一般推荐在qemu虚拟机中安装,这里仅做示例:
+sudo pacman -S docker
+
+安装完成后,需要启动Docker服务,并设置为开机自启:
+sudo systemctl start docker
+sudo systemctl enable docker
+
+运行以下命令来验证Docker是否正常工作:
+sudo docker run hello-world
+
+默认情况下,只有root用户才能运行Docker命令。为了避免每次运行Docker命令时都需要使用sudo,可以将当前用户添加到docker组:
+sudo usermod -aG docker $USER
+
+之后,需要注销并重新登录,或者重启系统以使更改生效。
+安装Docker Compose:
+sudo pacman -S docker-compose
+
+Done.
+ +前言 openwrt 是一个自由的、兼容性好的嵌入式 linux 发行版。作为软路由玩家必备的一款神器,可以实现诸如去广告,多拨和科学上网等多种功能。本文介绍openwrt在各种平台上的部署流程。
+无论是传统的无线路由器还是小主机都有成为openwrt路由的潜力。截止到今天,已经有20多个品牌(小米,华硕,锐捷,华三等)30多种架构(x86,ipq,bcm,mtd等)支持刷入openwrt;你可以在这个网站找到符合你预算和其他要求的,能刷机的路由器。 +传统家用无线路由器由于主频低,内存小,并不适合作为软路由;而 NAS-软路由一体式 又有 all in boom 的风险,因此推荐X86平台作为物理机。当然,也可以采用 armbian 平台或是开发板,例如网心云老母鸡、树莓派等设备。截至本文撰写时间,二手平台上的价格不太利好:一台J1900平台的售价往往在200左右,而专门的多网口工控机价格在200到1000不等,树莓派更是成为了理财产品,需要慎重选择。
+除了openwrt主线外,还可以选择:
+LEDE 高质量,更新快速,具有新特性的openwrt分支。
+iStoreOS iStoreOS是openwrt的一个分支,iStoreOS 提供了软件中心:iStore,以及较美观的界面和docker支持,对新手体验较好。
+ImmortalWrt 是一个原版openwrt的分支,中文优化好,更新也勤快,内置镜像源可以直连下载&更新。
+| 特性 | Toolchain | SDK | Image Builder |
|---|---|---|---|
| 包含内容 | 仅交叉编译工具链(二进制版 GCC、ld、musl、binutils) | 完整交叉编译环境 + feeds 脚本 + package 目录,用于 .ipk 包开发 | 预编译的根文件系统 + opkg 包(无需源码编译),用于快速定制固件映像 |
| 典型用途 | 用于编译第三方程序或 CI,如 hello-world 示例 | 编写和编译 .ipk 包,本地或自动化环境中离线开发 | 快速生成可刷写的固件镜像,集成所需包且无需完整源码树 |
| 解压即用 | ✅ | ✅ | ✅ |
| 在源码树中的作用 | make toolchain/install 自动识别并使用跳过编译流程 | 源码树中不会触发 SDK 安装,需要手动解压并进入其目录使用 | 不使用源码树,直接在 Image Builder 根目录下运行 make image 等命令 |
| 大小 | 较小(几十 MB) | 较大(上百 MB) | 中等(约数百 MB,因包含预编译包) |
| 构建时间 | 几秒到几分钟 | 几分钟到十几分钟(取决于 feeds 大小) | 极快,可在几十秒到几分钟内完成定制镜像 |
| 兼容性 | 与对应 Release 完全匹配 | 与对应 Release 完全匹配 | 与对应 Release 完全匹配 |
| 使用难度 | 简单,只需解压并设置 PATH | 适中,需要理解 feeds 机制及包管理 | 最简单,适合终端用户或快速测试环境 |
一个U盘与一台双网口物理机
+openwrt 的编译包,官方网站:OpenWrt Firmware Selector
+或者用由 eSir 大佬编译的懒人包
+PE 启动盘,这里推荐HotPE
+please press Enter to activate this console这个提示的时候系统就安装完毕了。可使用 passwd 命令设置密码。软路由将自动获取IP地址,随后我们在浏览器中打开该地址,即可看到 Lucl 界面。uci set luci.main.mediaurlbase='/luci-static/bootstrap' uci commit luci /etc/init.d/uhttpd restart
+然后重新访问 Web 界面,查看是否恢复正常。系统版本:Debian 11 或者 Ubuntu LTS
+网络要求:科学上网环境,配置推荐 2H4G 以上
+编译依赖
+sudo apt update
+sudo apt install -y \
+ ack antlr3 asciidoc autoconf automake autopoint binutils bison build-essential \
+ bzip2 ccache clang cmake cpio curl device-tree-compiler diffutils diffstat findutils flex gawk \
+ gcc-multilib g++-multilib git gettext gperf grep haveged help2man intltool \
+ libelf-dev libfuse-dev libgmp3-dev libgl1-mesa-dev libgraphene-1.0-dev libglib2.0-dev \
+ libltdl-dev libmpc-dev libmpfr-dev libncurses-dev libpython3-dev libreadline-dev libssl-dev \
+ libtool lrzsz make mesa-common-dev msmtp ninja-build p7zip p7zip-full patch pkgconf \
+ perl python-is-python3 python3 python3-dev python3-distutils-extra python3-pip python3-pyelftools \
+ python3-setuptools qemu-utils rsync scons squashfs-tools subversion swig texinfo uglifyjs \
+ upx-ucl unzip vim wget gnu-which xmlto xxd zlib1g-dev genisoimage llvm llvm-runtime docutils-common \
+ ecj fastjar java-wrappers libeclipse-jdt-core-java libgnutls-dane0t64 \
+ libgnutls-openssl27t64 libgnutls28-dev libidn2-dev libp11-kit-dev libtasn1-6-dev libtasn1-doc \
+ libunbound8 libyaml-dev lld lld-18 nettle-dev python3-docutils python3-ply python3-roman re2c
+
+sudo apt autoremove --purge
+sudo apt clean
+
+useradd -m openwrt # 新建一个名为 openwrt 的用户
+
+++不可以使用Root用户进行编译!!!
+
apt install -y sudo
+usermod -s /bin/bash openwrt
+
+su openwrt
+cd ~
+
+git clone https://github.com/immortalwrt/immortalwrt.git
+cd immortalwrt
+
+如果你想要编译稳定版(stable),使用
+git checkout xxx #例如git checkout v24.10.2
+
+如果你想要编译最新版(snapshot),使用
+git switch xxx #例如git switch openwrt-24.10
+
+| 名称 | 作用 |
|---|---|
Makefile | 整个 OpenWrt 构建系统的总入口点(顶层 Makefile),运行 make menuconfig、make 都依赖它 |
Config.in | Kconfig 系统的入口配置文件,决定 make menuconfig 菜单显示什么选项 |
config/ | 构建系统的默认配置模板、菜单逻辑,和 menuconfig 相关 |
include/ | 包含通用 makefile 片段的目录(比如编译选项、函数定义) |
rules.mk | 所有包编译通用规则都写在这里,include $(TOPDIR)/rules.mk 是常见语句 |
feeds.conf.default | 定义 Feed 源(即可选的软件源),可用于管理外部包,比如 luci、packages |
feeds/ (克隆后还没出现) | ./scripts/feeds update -a 后才会出现,用来保存外部 feed 的代码 |
package/ | OpenWrt 自带的核心包和第三方包(除 feeds 外的)都在这,结构是 package/<分类>/<包名> |
target/ | 支持的平台架构,比如 x86、ramips、ath79、mediatek 等都在里面 |
toolchain/ | 编译器链、glibc/musl、binutils、gcc 都在这里构建 |
tools/ | 构建工具目录,编译前工具如 m4、autoconf、xz、patch 等放在这 |
scripts/ | 脚本工具目录,如 feeds 管理、镜像合并、menuconfig 支持等 |
LICENSES/ | 所有包/组件的许可证归档 |
COPYING | OpenWrt 的主许可证(GPLv2) |
README.md | 简要介绍如何开始使用 OpenWrt 的说明文档 |
BSDmakefile | 为 BSD 系统一些兼容 makefile,Linux 用户用不到 |
vim feeds.conf.default
+
+常用源
+src-git kenzo https://github.com/kenzok8/openwrt-packages
+src-git small https://github.com/kenzok8/small
+src-git haibo https://github.com/haiibo/openwrt-packages
+src-git liuran001 https://github.com/liuran001/openwrt-packages
+
+常用仓库
+src/gz kwrt_core https://dl.openwrt.ai/releases/24.10/targets/x86/64/6.6.83
+src/gz kwrt_base https://dl.openwrt.ai/releases/24.10/packages/x86_64/base
+src/gz kwrt_packages https://dl.openwrt.ai/releases/24.10/packages/x86_64/packages
+src/gz kwrt_luci https://dl.openwrt.ai/releases/24.10/packages/x86_64/luci
+src/gz kwrt_routing https://dl.openwrt.ai/releases/24.10/packages/x86_64/routing
+src/gz kwrt_kiddin9 https://dl.openwrt.ai/releases/24.10/packages/x86_64/kiddin9
+
+git clone https://github.com/chenmozhijin/turboacc.git
+
+./scripts/feeds clean
+./scripts/feeds update -a
+./scripts/feeds install -a
+
+./scripts/feeds update -a | 同步/更新 外部 feed(packages、luci、routing 等)的 Git 仓库到本地 feeds/ 目录 |
|---|---|
./scripts/feeds install -a | 把你在 feeds 里选要用的包 链接 到源码树的 package/feeds/,让它们参与编译 |
#!/usr/bin/env bash
+# diy-part2.sh — 在镜像生成时注入默认设置和定制 SSH 横幅及模型修复
+
+# 1. 默认 hostname(可选)
+sed -i 's/=ImmortalWrt/=my-device/' package/base-files/files/bin/config_generate
+
+# 2. 默认 IP 地址(可选)
+sed -i 's/192.168.1.1/192.168.5.1/' package/base-files/files/bin/config_generate
+
+# 3. 默认 root 密码(请换成安全密码)
+HASH=$(openssl passwd -1 'yourpassword')
+sed -i "s|root::0:0:99999|root:${HASH}:0:0:99999|" package/base-files/files/etc/shadow
+
+# 4. 设置默认 LuCI 主题为 argon(内置在 luci feeds)
+cat >>package/base-files/files/etc/uci-defaults/99_set_theme <<'EOF'
+uci set luci.main.mediaurlbase=/luci-static/argon
+uci commit luci
+EOF
+chmod +x package/base-files/files/etc/uci-defaults/99_set_theme
+
+# 5. 默认加载 BBR 拥塞控制算法
+mkdir -p package/base-files/files/etc/sysctl.d
+cat >>package/base-files/files/etc/sysctl.d/99-bbr.conf <<'EOF'
+net.core.default_qdisc=fq_codel
+net.ipv4.tcp_congestion_control=bbr
+EOF
+
+# 检查BBR: sysctl net.ipv4.tcp_congestion_control
+
+# 6. 将默认 shell 修改为 bash
+sed -i "s|/bin/ash|/bin/bash|g" package/base-files/files/etc/passwd
+# 请在 .config 中添加 TARGET_PACKAGES += bash
+
+# 7. 自定义 SSH 登录横幅(banner)
+mkdir -p package/base-files/files/etc
+if [ -f "scripts/custom-files/banner.txt" ]; then
+ cp scripts/custom-files/banner.txt package/base-files/files/etc/banner
+else
+ cat >package/base-files/files/etc/banner <<'EOF'
+Welcome to MyDevice (ImmortalWrt)\n
+EOF
+fi
+
+# 8. 自定义 LuCI 概览设备型号 🛠
+# 通过 uci-defaults 脚本写入 /tmp/sysinfo/model
+cat >>package/base-files/files/etc/uci-defaults/99-model-fix <<'EOF'
+#!/bin/sh
+# 设置自定义设备型号
+mkdir -p /tmp/sysinfo
+echo "Your Router Model" > /tmp/sysinfo/model
+exit 0
+EOF
+chmod +x package/base-files/files/etc/uci-defaults/99-model-fix
+
+| 命令 | 功能描述 | 优点 | 适用场景 |
|---|---|---|---|
make menuconfig | 以 ncurses 界面交互式地浏览、修改当前 .config 与最新 Kconfig 中的所有选项 | 界面友好,支持搜索和分类;可直观调整 | 想手动挑选/调整配置时 |
make oldconfig | 在命令行逐项对比 .config 与最新 Kconfig:保留原值、提示新增项、删除废弃项 | 快速同步,只对新增选项发出提示;无需界面 | 自动化脚本或快速同步配置时 |
make defconfig | 忽略当前 .config,直接加载架构/板级目录下的默认配置(defconfig) | 一键生成官方/平台推荐的「干净」配置 | 想重置到官方默认或重新开始时 |
Target System (x86) # 选择目标平台
+└── Subtarget (x86_64) # 选择 64-bit 子架构
+ └── Target Profile (Generic) # “Generic” 表示通用 x86_64 设备
+ └── Target Images # 固件镜像设置
+ ├── ramdisk # 可选内存盘镜像
+ │ ├── Compression # 压缩类型(如 none 表示无压缩)
+ │ ├── Root filesystem archives # 压缩存档:cpio.gz 或 tar.gz
+ │ └── Root filesystem images # 文件系统镜像:ext4、squashfs、Gzip
+ └── Image Options # 镜像选项
+ ├── Kernel partition size # 内核分配分区大小
+ ├── Root filesystem partition size # 根文件系统分区大小
+ └── Make /var persistent # 是否保留 /var 持久化
+
+Global build settings # 全局构建设置
+Advanced configuration options (for developers) # 开发者高级选项
+Build the OpenWrt Image Builder # 编译镜像构建器
+Build the OpenWrt SDK # 构建交叉编译 SDK
+Package the OpenWrt‑based Toolchain # 打包 OpenWrt 工具链
+Image configuration # 镜像总体配置页面
+
+Base system # 系统基础组件
+Administration # 管理工具(如 ssh、管理员脚本)
+Boot Loaders # 引导程序(如 grub、syslinux)
+Development # 编译/调试辅助工具
+Extra packages # 附加应用(如 wget、curl)
+Firmware # 固件工具
+Fonts # 字体支持
+Kernel modules # x86 内核模块驱动
+Languages # 编程语言包(如 Python3、Node.js)
+Libraries # 系统库依赖
+LuCI # Web UI 前端
+└── Collections
+└── Modules
+└── Applications
+└── Themes
+└── Protocols
+└── Libraries
+└── default‑settings
+
+Mail # 邮件客户端
+Multimedia # 媒体工具(如 ffmpeg)
+Network # 网络功能(如 openvpn、wireguard)
+Sound # 音频相关软件
+Utilities # 常用实用程序(如 vim、htop)
+Xorg # 桌面环境支持(X11 图形系统)
+
+
+make download -j8
+
+find dl -size -1024c -exec ls -l {} \;
+
+检查文件完整性命令可以列出下载不完整的文件,小于1k的文件属于下载不完整,如果存在则用下面的命令删除,然后重新下载编译所需的软件包,再次检查.确认所有文件完整可大大提高编译成功率,避免浪费时间
+find dl -size -1024c -exec rm -f {} \;
+
+make V=s -j1
+
+或者使用 make world -j1 V=s 2>&1 | tee world_debug.log
+
+如果报错可查看 grep -E "(error|fatal|Cannot install package)" world_debug.log -n
+
+| make层级 | 目录示例 | 说明 |
|---|---|---|
| make[1] | 顶层 Makefile | 解析依赖,调度模块 |
| make[2] | tools/ | 编译辅助工具 |
| make[2] | toolchain/ | 编译交叉编译工具链 |
| make[2] | target/linux/ | 编译内核及设备树 |
| make[2] | package/ | 进入包管理,调度包构建 |
| make[3] | package/libs/libc | 单个包的 Makefile |
| make[3] | package/utils/busybox | 单个包的 Makefile |
| make[4] | build_dir/target-... | 包源码目录,运行源码的 make |
| make[4] | build_dir/target-linux-... | 内核源码目录 |
| 命令 | 清除内容 | 保留内容 | 适用场景 |
|---|---|---|---|
make clean | 删除 bin/ 镜像、build_dir/ 编译产物 | .config、staging_dir/、toolchain/ 等 | 小修改后重建镜像,速度快,常用于增量编译。 |
make dirclean | 和 make clean 一样,还删除 staging_dir/、toolchain/、logs | .config | 彻底重建交叉编译环境,适合更改编译配置如 .config、feeds 等。 |
make distclean | 删除 make dirclean 的所有内容 + feeds 下载文件 + .config、patch 等所有状态 | 只有源码目录保持不变 | 专用于回到一个“零配置、重做一切”的状态,完全从头开始构建。 |
恢复所有修改(包括未跟踪文件):
+git clean -fd
+git restore --source=v24.10.2 --staged --worktree .
+
+| 作用 | 组件 |
|---|---|
| 主题 | argon |
| Shell | bash |
| SSH 服务器 | dropbear |
| Web 服务器 | uhttpd |
| DNS/DHCP 服务 | dnsmasq‑full |
| 加密库 | openssl |
| 压缩算法 | zram+zstd |
| 拥塞控制 | bbr |
| 防火墙 | nftables + iptables |
| 调度模块 | BPF + kmod-sched-xxx |
| 时间同步 | ntpd-full |
| 文本编辑 | vim-full vim-runtime |
| 编译优化 | LTO + O3 |
要启用的软件包:
+base
+autocore base-files bash block-mount ca-bundle coremark curl dnsmasq-full dropbear ds-lite e2fsprogs fdisk firewall4 fstools grub2-bios-setup htop kmod-8139cp kmod-8139too kmod-amazon-ena kmod-amd-xgbe kmod-atlantic kmod-bnx2 kmod-bnx2x kmod-button-hotplug kmod-drm-amdgpu kmod-drm-i915 kmod-dwmac-intel kmod-e1000 kmod-e1000e kmod-forcedeth kmod-fs-f2fs kmod-fs-vfat kmod-i40e kmod-iavf kmod-igb kmod-igbvf kmod-igc kmod-ixgbe kmod-ixgbevf kmod-lib-zstd kmod-mlx4-core kmod-mlx5-core kmod-mmc kmod-pcnet32 kmod-phy-broadcom kmod-r8101 kmod-r8125 kmod-r8126 kmod-r8168 kmod-sdhci kmod-tcp-bbr kmod-tg3 kmod-tulip kmod-usb-hid kmod-vmxnet3 libc libgcc libustream-mbedtls lm-sensors-detect logd lsblk luci-app-fan luci-app-filemanager luci-app-firewall luci-app-log-viewer luci-app-package-manager luci-app-syscontrol luci-app-upnp luci-base luci-compat luci-lib-fs luci-lib-ipkg mkf2fs mtd nano netifd odhcp6c odhcpd-ipv6only openssh-sftp-server opkg partx-utils pciutils ppp ppp-mod-pppoe resolveip swconfig uci uclient-fetch urandom-seed urngd usbutils wget-ssl zram-swap
+
+cli
+btop iperf3 tcpdump
+
+luci
+luci-app-argon luci-app-upnp luci-app-ttyd luci-app-eqosplus luci-app-timecontrol luci-app-parentcontrol luci-app-homeproxy luci-app-daed
+
+lib
+kmod-ipt-conntrack kmod-ipt-nat kmod-nft-compat kmod-ipt-fullconenat kmod-ip6tables ca-certificates
+
+首先新建一个文件夹并将SDK克隆下来:
+mkdir imwrt-sdk
+cd ./imwrt-sdk
+wget https://downloads.immortalwrt.org/snapshots/targets/mediatek/filogic/immortalwrt-sdk-mediatek-filogic_gcc-14.3.0_musl.Linux-x86_64.tar.zst
+
+新版本的SDK使用ZSTD压缩,因此解压的命令为
+tar -I zstd -xvf ./immortalwrt-sdk-mediatek-filogic_gcc-14.3.0_musl.Linux-x86_64.tar.zst
+
+随后进入该目录并和一般流程一样更新Feeds:
+cd ./immortalwrt-sdk-mediatek-filogic_gcc-14.3.0_musl.Linux-x86_64/
+./scripts/feeds update -a
+./scripts/feeds install -a
+
+更新完成后克隆你要编译的包的源码到package下:
+cd ./package/
+git clone https://github.com/Dichgrem/luci-app-nyn.git
+cp ./luci-app-nyn/luci-app-zzz ./
+cp ./luci-app-nyn/zzz ./
+rm -rf ./luci-app-nyn
+cd ../
+
+随后开始编译,编译结果在对应架构的base目录下:
+make package/luci-app-zzz/compile V=s
+
+~/imwrt-sdk/immortalwrt-sdk-24.10.3-x86-64_gcc-13.3.0_musl.Linux-x86_64 dich@uos
+❯ find ./ -name "zzz*.ipk"
+./bin/packages/x86_64/base/zzz_0.1.1-r1_x86_64.ipk
+
+# 更新软件列表
+opkg update
+
+# 更新所有 LUCI 插件
+opkg list-upgradable | grep luci- | cut -f 1 -d ' ' | xargs opkg upgrade
+
+# 如果要更新所有软件,包括 OpenWRT 内核、固件等
+opkg list-upgradable | cut -f 1 -d ' ' | xargs opkg upgrade
+
+# 固件版本号
+vim /etc/os-release
+
+# 脚本&脚注
+vim /etc/openwrt_release
+
+# ASCII字符画
+vim /etc/banner
+
+# 登录脚本显示
+vim /etc/profile
+
+| 特性 | HomeProxy | OpenClash | Passwall | ShellClash |
|---|---|---|---|---|
| 核心 | Sing-box、Xray | Clash | Xray、Sing-box | Clash、Xray、Sing-box |
| UI 管理 | ✅(Web UI、桌面端 GUI) | ✅(OpenClash Web UI) | ✅(Luci Web UI) | ❌(Shell 终端管理) |
| 适用场景 | 性能较好,但分流设置复杂 | 适用于clash系,机场首选 | 操作简单,分流完善,但对路由器性能要求较高 | 没有UI界面,性能最好,支持完善,可以通过clashapi安装UI |
常见检测方法:
+高性能开销检测方法:
+++高性能开销的检测方法会浪费大量性能,一般很少有学校这么做。IP-ID和Flash检测法如今已经不多见。
+
TTL修复:
+依赖包
+opkg install kmod-nft-core kmod-nft-bridge kmod-nft-net kmod-nft-offload kmod-nft-nat
+
+首先检查 mangle 表是否存在
+nft list tables
+
+创建 mangle 表(如果不存在)
+nft add table ip mangle
+
+创建 POSTROUTING 链(如果不存在)
+nft add chain ip mangle POSTROUTING { type nat hook postrouting priority 0 \; }
+
+
+添加 TTL 规则
+nft add rule ip mangle POSTROUTING ip ttl set 64
+
+检查规则是否生效
+nft list table ip mangle
+
+有时候我们使用X86做主路由,想让无线路由器只起到发射信号的作用,就可以将其改为AP模式,一般步骤为:
+前言 假期将至,不少家里有闲置设备的小伙伴想尝试开设一个我的世界(Minecraft)服务器,却不知从何下手。本文以 PVE-Debian-MCSM 为主线介绍其部署流程。
+PVE (全称 Proxmox Virtual Environment) 是一款开源免费的虚拟化环境平台,同时支持KVM 虚拟机和 LXC 容器。它基于 Debian 和 KVM 技术开发,可在一台 PC 或服务器上同时运行Linux、OpenWRT、Windows 等,实现计算、网络、存储一体化解决方案,即所谓的“all in one”。类似的平台还有ESXi、Unraid等。
+MCSManager 面板(简称:MCSM 面板)是一款全中文,轻量级,开箱即用,多实例和支持 Docker 的 Minecraft 服务端管理面板。
+此软件在 Minecraft 和其他游戏社区内中已有一定的流行程度,它可以帮助你集中管理多个物理服务器,动态在任何主机上创建游戏服务端,并且提供安全可靠的多用户权限系统,可以很轻松的帮助你管理多个服务器。 +具体步骤:安装PVE并优化,开设虚拟机并安装Debian,安装mscm界面并开设实例,配置网络服务。
+2.Debian镜像(不建议使用DVD版,会出现奇怪的问题。)
+1.将下载好的镜像用Rufus写入U盘。
+2.将U盘插到目标主机上面,进入BIOS-boot设置启动顺序。这里我使用二手浪潮服务器X99主板,矿龙电源以及一块128G的SSD固态。注意:大部分服务器主板有机箱入侵检测机制,需要在说明书中找到特定针脚并用导电帽盖上,否则无法开机。
+3.进入安装界面,选择install; +随后跑码,进入如下界面,同意协议: +设置硬盘与文件类型,可以选择ext4或者btrfs; +选择国家与地区,这里需要手打出China; +随后设置密码与邮件,邮件可以随便填: +然后设置网络连接,这里插网线就有地址;设置主机名,并记下内网IP地址; +检查无误后开始安装: +安装完成后 reboot。
+4.浏览器打开 PVE 地址,进入系统后我们需要给PVE换源。
+禁用 Ceph 企业仓库:
+nano /etc/apt/sources.list.d/ceph.list
+
+将文件内容注释掉或删除。
+编辑仓库源文件:
+nano /etc/apt/sources.list.d/pve-enterprise.list
+
+将文件内容注释掉或删除;
+启用社区仓库:
+确保社区仓库已启用。编辑社区仓库文件:
+nano /etc/apt/sources.list.d/pve-no-subscription.list
+
+确保文件内容如下:
+deb http://download.proxmox.com/debian/pve bookworm pve-no-subscription
+
+1.找到 local-btrfs(pve),在其中的 ISO 中上传下载好的 Debian 镜像;
+2.随后创建虚拟机,选择 Debian 镜像并设置 CPU 核数与硬盘、内存大小;
+3.一路确认后开机进入命令行界面,即可开始Debian安装。我们选择graphical install:
+4.选择国家和语言,随后自动配置网络;
+5.设置主机名,跳过域名设置;设置 root 账户名和密码、普通用户账户名与密码;
+6.对磁盘进行分区,由于是虚拟机我们选择使用整个磁盘;
+7.安装基本系统,随后将进入包管理器和大组件安装;
+我们选择清华源,速度较快。注意:Debian 安装时默认开启安全源,这个源是国外的所以下载速度极慢,因此还需要修改配置文件。
+在安装步骤进入到选择安装的桌面环境和软件时, 键入 Ctrl+Alt+F2 可以看到从图形界面转到了tty命令终端, 键入 Enter +这里修改软件源配置文件
+nano /target/etc/apt/sources.list
+
+修改debian-security源地址 http://mirrors.ustc.edu.cn 目测最快
deb http://mirrors.ustc.edu.cn/debian-security bullseye-security main
+
+修改后 Ctrl+X 退出保存,然后退出终端重新进入界面继续安装,键入 Ctrl+Alt+F5。
+下载需要一些时间,此时可以饮口茶先,随后看到如下界面:
+由于是服务器所以不需要桌面环境:
+安装 grub 引导:
+随后安装完成,reboot后进入mscm的安装。
+1.开机进入tty1界面
+2.安装JAVA环境,不同版本的游戏的 Java 版本也不同。这里我们使用1.19版,需要安装 Java18。
+安装 wget 和 下载 Java18
+apt install wget && wget http://img.zeruns.tech/down/Java/OpenJDK18U-jre_x64_linux_hotspot_18.0.1_10.tar.gz
创建安装目录
+mkdir /usr/local/java/
解压当前目录下的 JDK 压缩文件
+tar -zxvf OpenJDK18U-jre_x64_linux_hotspot_18.0.1_10.tar.gz -C /usr/local/java/
软链接程序到环境变量中
+ln -sf /usr/local/java/jdk-18.0.1+10-jre/bin/java /usr/bin/java
测试是否安装正常,显示 openjdk version "18.0.1" 2022-04-19 则为正常
java -version
3.端口开发,面板需要 23333和24444 端口,游戏服务器默认端口是 25565。
+在 PVE-防火墙中打开它们。如果还是不行,执行如下命令:
+systemctl stop firewalld
+
+systemctl disable firewalld
+
+service iptables stop
+
+从而关闭防火墙。
+4.安装面板,这里使用一键安装命令(注意该脚本仅适用于 AMD64 架构)
+wget -qO- https://gitee.com/mcsmanager/script/raw/master/setup.sh | bash
执行完成后,使用 systemctl start mcsm-{web,daemon} 即可启动面板服务。使用 systemctl enable mcsm-{daemon,web}.service 实现开机自启。
5.在浏览器中打开该地址加上23333端口后缀,即可看到面板,账户为root,密码为123456。
+6.新建实例,上传 Purpur1.19 服务端,设置名称随后开启实例
+7.随后我们可以在 配置文件中设置游戏的相关选项,如关闭正版验证等。
+8.大功告成,此时打开 HMCL 启动器,即可加入游戏。
+1.此时不要忘记需要和小伙伴们一起玩耍。如果你家里有公网固定 IPv4 或者 IPv6,直接输入联机即可;如果没有公网IP,此时就需要进行内网穿透或者DDNS。
+这里介绍一种名为 zerotier 的工具。
+2.首先在 https://www.zerotier.com/ 注册并创建一个私有网络;
+3.首先在虚拟机中安装 curl 命令支持
+apt-get install curl
4.安装gnupg非对称信息加密系统,通讯所需必备软件
+apt-get install gnupg
5.安装 ZeroTier
+curl -s https://install.zerotier.com/ | bash
安装成功后提示如下:
+Success! You are ZeroTier address [ xxxxxxxxx ].
方括号内地址为类似于MAC地址。
+6.设定开机自启动(分别执行如下命令)
+systemctl start zerotier-one.service
systemctl enable zerotier-one.service
7.加入自己的私有网络
+zerotier-cli join xxxxxxxxx
8.大功告成!此时只要让小伙伴们下载 zerotier 客户端并加入相同的私有网络,即可一起快乐联机!
+ +前言 linux搭建安卓虚拟机有Waydroid,QEMU和Docker三种方案,各有不同。
+Waydroid是Anbox配合Halium技术开发的LXC Android容器,可在GNU/Linux系统执行Android APP。以下是Waydroid的特色功能:
+++Waydroid执行时的Android系统资料放在
+~/.local/share/waydroid/data/,系统映像档位于/var/lib/waydroid,APP图示位于~/.local/share/applications/
目前Waydroid只支持Intel和AMD的显卡,对于 NVIDIA 显卡(除 Tegra 系列外),Waydroid 不支持硬件加速,推荐使用软件渲染或QEMU方案。
+echo $XDG_SESSION_TYPE
+
+若显示X11代表不是Wayland。GNOME和KDE可在登入画面切换至Wayland工作阶段。
+paru -S binder_linux-dkms
+
+sudo modprobe binder-linux devices=binder,hwbinder,vndbinder
+
+echo "binder_linux" | sudo tee -a /etc/modules-load.d/binder_linux.conf
+
+echo "options binder_linux devices=binder,hwbinder,vndbinder" | sudo tee -a /etc/modprobe.d/binder_linux.conf
+
+paru -S wl-clipboard xclip
+paru -S python-pyclip
+
+paru -S waydroid
+
+sudo waydroid init -s GAPPS -f
+
+sudo systemctl start waydroid-container
+
+sudo systemctl enable waydroid-container
+
+waydroid show-full-ui
+
+sudo ufw allow 53
+sudo ufw allow 67
+sudo ufw default allow FORWARD
+sudo ufw reload
+sudo systemctl restart waydroid-container
+
+sudo systemctl restart waydroid-container
+
+sudo systemctl start waydroid-container
+sudo systemctl stop waydroid-container
+
+waydroid show-full-ui
+
+waydroid log
+sudo waydroid logcat
+
+安装Rotation Control这类APP,即可强制调整Waydroid屏幕方向.
+安装Package Manager,用於查看APP的软件包名称。
+部份APP会要求开启Wifi才能上网,那么就如它所愿,开启fake wifi:
+waydroid prop set persist.waydroid.fake_wifi "软件包名称"
+
+例如给Fate/Go游戏开启模拟Wifi:
+waydroid prop set persist.waydroid.fake_wifi "com.aniplex.fategrandorder"
+
+安装Package Manager,用於查看APP的软件包名称。有些APP认不到鼠标点击,需要启用模拟触控(fake touch):
+waydroid prop set persist.waydroid.fake_touch "软件包名称"
+
+例如给Fate/Go游戏开启模拟触控:
+waydroid prop set persist.waydroid.fake_touch "com.aniplex.fategrandorder"
+
+waydroid app install <APK档案路径>.apk
+
+sudo waydroid shell
+
+Waydroid的多视窗模式,看起来像Linux的原生应用。启动后按F11改回来。
+waydroid prop set persist.waydroid.multi_windows true
+sudo systemctl restart waydroid-container
+
+Waydroid第一次开机可能会收到Device is not Play Protect certified的通知,无法登入Google账号。
用以下命令取得Waydroid的装置ID。该命令会印出一长串数字。
+sudo waydroid shell
+
+ANDROID_RUNTIME_ROOT=/apex/com.android.runtime ANDROID_DATA=/data ANDROID_TZDATA_ROOT=/apex/com.android.tzdata ANDROID_I18N_ROOT=/apex/com.android.i18n sqlite3 /data/data/com.google.android.gsf/databases/gservices.db "select * from main where name = \"android_id\";"
+
+开启装置注册页面,登入Google账号,输入装置ID注册,等个半小时应该就能登入Google账号了。如果还是不行就重新启动Waydroid容器服务:
+sudo systemctl restart waydroid-container
+
+现在可以安装APP了,Google Play和F-Droid会自动筛出適合x86架构的APP。
+Bliss OS 是基于 Android-x86 的开源系统,已更新至 Android 13,并内建 Google Play 商店,可直接运行 64 位 APK,无需额外转译器;在 Linux 上通过 QEMU/KVM + virglrenderer 实现 GPU 加速,使得在虚拟机中也能流畅体验手游。
+VT-x/AMD-V,并加载 KVM 内核模块;Intel 10 代及更新集成 GPU 可用,AMD 同理;闭源 Nvidia 驱动下 virglrenderer 不稳定,不建议使用硬件加速。Q35 芯片组、UEFI (OVMF)。ef00),挂载点 /mnt/efi;blkid 找到 EFI 分区(如 /dev/sda1),挂载后编辑 /mnt/efi/boot/android.cfg:
+linux $kd/kernel 行末添加 video=1920x1080;set gfxmode= 为相应分辨率,保存并重启即可生效。com.android.shell 授予 Root 权限。ReDroid(Remote-Android)是一款开源的容器化 Android 解决方案,支持在 x86 主机通过 Docker、Podman 或 Kubernetes 启动多实例 Android 系统,并提供 GPU 加速与多架构(arm64/amd64)支持,适用于云端游戏、自动化测试、虚拟手机等场景。本文从环境准备、部署配置、日常使用及进阶定制等方面,逐步讲解如何在 Linux 主机上用 Docker 容器运行并优化 ReDroid,使其能够流畅运行 ARM 架构的手游。
+binderfs、ashmem 等内核模块,部分发行版可能需安装 redroid-modules。mkdir ~/redroid && cd ~/redroid
+vim docker-compose.yml
+
+docker-compose.ymlversion: '3.8'
+services:
+ redroid:
+ image: redroid/redroid:11.0.0_gapps
+ stdin_open: true
+ tty: true
+ privileged: true
+ ports:
+ - "127.0.0.1:5555:5555"
+ volumes:
+ - ./redroid-11-data:/data
+ command:
+ - androidboot.redroid_width=720
+ - androidboot.redroid_height=1280
+ - androidboot.redroid_dpi=320
+ - androidboot.redroid_fps=60
+ - androidboot.redroid_gpu_mode=host
+ - ro.product.cpu.abilist0=x86_64,arm64-v8a,x86,armeabi-v7a,armeabi
+ - ro.enable.native.bridge.exec=1
+ - ro.dalvik.vm.native.bridge=libndk_translation.so
+
+sudo docker compose up -d
+
+adb connect localhost:5555
+scrcpy -s localhost:5555 --audio-codec=aac
+
+adb install your_app.apksudo docker compose down
+sudo docker compose up -d
+
+~/redroid/redroid-11-data,可备份或运行多实例。system 目录,再在容器内推送并授权。redroid:13.0.0-latest 的自定义镜像,提升兼容性与性能。🔗
+ +Done.
+ +前言 本文记录Android命令行开发环境在Linux上的部署,用以替代Android-studio。
+前言 本文记录STM32命令行开发环境在Linux上的部署,用以替代Windows上的RT-Thread-studio。RT-Thread-studio同样是开源 +软件,但目前没有Nixos上的打包。
+前言 PGP/GPG 的核心功能——公钥加密、数字签名、信任管理广泛用于各个行业,本文简单说明了其使用方法。
+前言 SSH(Secure Shell 的缩写)是一种网络协议,用于加密两台计算机之间的通信,并且支持各种身份验证机制。
+前言 本文面向刚刚从Windows转向Linux的一般使用者和想在Linux上进行开发的开发者,主要说明其系统特点和使用须知。
+Linux 是一种开源的类 UNIX 操作系统内核,广泛应用于各种设备,包括个人计算机、服务器、手机、嵌入式系统等。它由芬兰的 Linus Torvalds 于1991年开始开发,是一个自由、免费的操作系统。与 Windows 和 macOS 等操作系统不同,Linux 的源代码对所有人开放,任何人都可以查看、修改和重新分发。我们常常说的Linux,实际上是指各种发行版,比如Ubuntu,Arch Linux,Debian等等。
+++Liunx可以用来玩游戏吗? +实际上著名的 Steam Deck 的系统就是基于Arch linux 的。对于个人使用而言,现在有不少原生支持linux 的游戏;也可以使用Wine来运行Windows下的游戏。
+
Linux操作系统主要由以下几个部分组成:
+从上文可以发现,选择Linux发行版实际上是在选择 内核/包管理器/图形界面 等组件的排列组合。其中最主要的因素是包管理器。
+Linux有许多不同的发行版,但大致可以分为几个系:
+Debian系:
+Debian:Debian以稳定性,安全性和轻量级著称,适合用于服务器和桌面环境。我们常说的Ubuntu就是基于Debian的发行版,注重用户友好性和易用性。它提供了多种桌面环境选择,以及许多现成的软件包。
+APT(Advanced Package Tool)是Debian系发行版的主要包管理器。它使用命令行工具如apt-get、aptitude等来管理软件包。
+Red Hat系:
+Arch系:
+Arch Linux:Arch Linux是一个简洁、轻量级且灵活的发行版,注重简洁性和滚动更新。它采用“滚动发布”的方式,用户可以通过自定义安装来构建自己的系统,适合有一定Linux经验的用户。
+Pacman(Package Manager)是Arch Linux的主要包管理器。它使用简洁的命令来管理软件包,如pacman -S安装软件包、pacman -Syu更新系统等。
+Gentoo系:
+Gentoo:Gentoo是一个源码驱动的发行版,用户可以通过源代码自定义编译软件包以满足自己的需求。它注重性能和灵活性,适合高级用户和技术爱好者。
+Portage是Gentoo的包管理器,它是一个源代码驱动的包管理器,允许用户从源代码构建和安装软件包。
+除了以上列举的包管理器外,还有其他一些较为特殊的包管理器,如Slackware系的pkgtool、SUSE系的zypper等。
+对于个人使用而言,我个人建议新手使用Ubuntu,有比较易用的界面和完善的资料参考;如果你是一个系统极客,可以使用Arch linux 或者 NixOS。
+李华是一个从WindowsXP时代一直使用到Win11的微软“老资历”用户,这一天,他下定决心要学会使用Linux!于是他按照网上CSDN的教程,在VMware中安装了大名鼎鼎的Ubuntu系统!但很快他发现,为什么系统里面没有C盘和D盘,只有一个神秘的/和一堆奇怪的英文?
在 Windows 的世界里,存储设备是用字母区分的,比如C: D: E:等等。但Linux 不给磁盘分字母,它采用的是一种叫做 FHS(Filesystem Hierarchy Standard,文件系统层次结构标准) 的方式来组织系统。在 FHS 的世界里,整个系统就像一棵树:
因此对于Linux而言,文件系统是这样的:
+/ — 根
+/home — 用户家目录
+/root — 超级用户的家
+/bin — 基础命令/二进制文件
+/sbin — 管理命令
+/usr — 大多数程序和资源
+/lib — 库文件
+/etc — 配置文件
+/var — 日志、缓存、变化的数据
+/tmp — 临时文件
+/dev — 设备文件
+/media — 自动挂载U盘
+/mnt — 手动挂载点
+/opt — 第三方软件
+/boot — 系统启动文件
+/proc — 虚拟进程信息
+/sys — 虚拟硬件信息
+/run — 系统运行状态
+
+其中Home目录类似Windows上的C:\Users\你的名字,里面有桌面/文档/下载/图片/音乐/视频/,是不是非常眼熟?
可以看出,Linux下是不用专门分出系统盘和数据盘的,某种意义上解决了Windows的C盘空间不足红色爆满的问题。
+++小知识:为什么Windows上是“\”而Linux是“/”? Unix 在1970年代就使用“/”,诞生于 1980 年代的 MS-DOS 本来也是用“/”的!但后来微软加入了命令行参数(如 /help),和路径冲突了。为了区分选项和路径,微软紧急决定:“/” 用来当选项前缀(至今仍如此:dir /a),文件路径改用“\”,于是 Windows 专门和全世界不一样。
+
++并非所有Linux发行版都遵守FHS,比如Nixos.
+
理解了FHS,下一步就是,要如何安装软件呢?
+在windows中,当我们想要安装某个软件的时候,第一时间就是去寻找EXE安装包,而后点击安装-确定,软件就出现在桌面了!但李华很快发现,他将下载的EXE文件放在Ubuntu的桌面并点击,显示无法运行?
这是因为Linux下不使用Windows的PE格式,而是用ELF格式;这并不是说李华得手动一个个下载ELF并点击运行,实际上Linux上使用的是名为包管理器的方法。
在Ubuntu的界面中李华看到了一个名为终端的应用,输入apt install neofetch,就安装成功...不,暂时还没有成功,再次输入sudo apt install neofetch,就成功安装了neofetch这个软件,随后我们输入neofetch,可以看到系统的一些信息:
❯ neofetch
+ .-/+oossssoo+/-. dich@uos
+ `:+ssssssssssssssssss+:` --------
+ -+ssssssssssssssssssyyssss+- OS: Ubuntu 24.04.3 LTS x86_64
+ .ossssssssssssssssssdMMMNysssso. Host: KVM/QEMU (Standard PC (Q35 + ICH9, 2009) pc-q35-10.0)
+ /ssssssssssshdmmNNmmyNMMMMhssssss/ Kernel: 6.14.0-35-generic
+ +ssssssssshmydMMMMMMMNddddyssssssss+ Uptime: 2 mins
+ /sssssssshNMMMyhhyyyyhmNMMMNhssssssss/ Packages: 2522 (dpkg), 12 (snap)
+.ssssssssdMMMNhsssssssssshNMMMdssssssss. Shell: zsh 5.9
++sssshhhyNMMNyssssssssssssyNMMMysssssss+ Resolution: 1280x800
+ossyNMMMNyMMhsssssssssssssshmmmhssssssso Terminal: /dev/pts/0
+ossyNMMMNyMMhsssssssssssssshmmmhssssssso GPU: 00:01.0 Red Hat, Inc. Virtio 1.0 GPU
++sssshhhyNMMNyssssssssssssyNMMMysssssss+ Memory: 1126MiB / 13976MiB
+.ssssssssdMMMNhsssssssssshNMMMdssssssss.
+ /sssssssshNMMMyhhyyyyhdNMMMNhssssssss/
+ +sssssssssdmydMMMMMMMMddddyssssssss+
+ /ssssssssssshdmNNNNmyNMMMMhssssss/
+ .ossssssssssssssssssdMMMNysssso.
+ -+sssssssssssssssssyyyssss+-
+ `:+ssssssssssssssssss+:`
+ .-/+oossssoo+/-.
+
+可见,在Linux上安装软件其实比Windows的简单,只需一行命令,包管理器会从源下载软件包,并进行解压,处理依赖项/动态链接/环境变量等等;这并非代表不安全,Linux上大部分是开源软件;关于开源软件,日后我们再进行说明。那么,如何知道安装需要的命令呢?
我们可以从Ubuntu的软件源https://packages.ubuntu.com/上搜索软件包的名字,输入关键字(如 firefox、python、vlc),它会列出:
或者使用apt search 包名;如果apt没有某个包,还可以使用AppImage / Flatpak / Snap等等管理器来下载。
++包管理器常用命令
+
| 功能 | apt(Ubuntu/Debian) | paru/pacman(Arch/Manjaro) | 说明 |
|---|---|---|---|
| 更新软件包索引 | sudo apt update | sudo paru -Sy | 先更新仓库信息 |
| 升级已安装的软件 | sudo apt upgrade | sudo paru -Syu | 升级所有已安装的软件(包含系统更新) |
| 安装软件包 | sudo apt install <package> | sudo paru -S <package> | 安装指定软件 |
| 移除软件包(保留配置) | sudo apt remove <package> | sudo paru -R <package> | 删除软件包,但保留配置文件 |
| 完全删除软件包(含配置) | sudo apt purge <package> | sudo paru -Rns <package> | 删除软件包及依赖、配置文件 |
| 搜索软件包 | apt search <package> | paru -Ss <package> | 查找仓库中的软件包 |
| 查看已安装软件 | apt list --installed | paru -Q | 列出系统已安装软件 |
| 查看软件信息 | apt show <package> | paru -Si <package> | 显示软件包详细信息 |
| 自动清理无用依赖 | sudo apt autoremove | sudo paru -Rns $(pacman -Qdtq) | 删除不再需要的依赖包 |
| 清理下载缓存 | sudo apt clean | sudo paru -Sc | 删除已下载的软件包缓存 |
| 升级单个软件包 | sudo apt install --only-upgrade <package> | sudo paru -S <package> | 仅升级指定软件 |
++AppImage:可直接运行,像“可携带版 EXE”;Flatpak:沙盒化、现代、安全;Snap:由 Ubuntu 官方主推;第三方仓库 PPA:常见于开发版软件...
+
++如果你使用其他Linux发行版,也有对应的包管理器。比如Arch的Pacman/Paru,Fedora 的 dnf,openSUSE 的 zypper,NixOS 的 nix...
+
++实际上Windows上也是有包管理的,比如 Windows 10/11 内置的 winget(Windows Package Manager),choco(Chocolatey),scoop...由于历史原因不为大部分人所熟悉.可以使用这个项目UniGetUI在Windows上方便的进行包管理.
+
还记得前面我们使用的sudo apt install xxx吗?为什么不加上sudo就无法运行呢?这其实和Linux的权限系统有关.在Windows中有些无法直接运行的软件,需要右键单击并选择以管理员权限运行.这表示某个操作会修改系统,需要管理员(Administrator)的允许。Linux 也有类似的概念,但名字不一样,Linux 的管理员叫:root.
在Linux中,普通用户(如你的账户)只能管理自己的文件、自己的程序
+,而root 用户能管理整个系统、安装软件、删除系统文件、修改配置;所以,日常使用的时候不是“管理员账号”,而是一个安全的普通用户。sudo(super user do)就是:“请允许我暂时以 root 的身份执行这一条命令。”
为什么不用 root 账号直接登录呢?因为 root 太强大了:
+所以日常使用 root 类似于:“天天坐在一个自带核弹按钮的办公桌前”。这就是为什么 Linux 默认让你用普通用户,然后用 sudo 临时提升权限。
当李华学会使用 sudo 后,他又开始好奇:
++“为什么有些文件我能读,有些不能? +为什么有些文件能执行,有些却提示权限不够?”
+
Linux 的权限可以简单理解为UGO+RWX.
UGO由用户(User)/ 用户组(Group)/ 其他人(Others)构成,每个文件都有 Owner(所有者)和 Group(用户组)。
+RWX权限分为 r 读 / w 写 / x 执行,并以类似 -rwxr-x--- 的形式展示(文件类型 + Owner 权限 + Group 权限 + Others 权限)。
用户组(Group) 是“权限相同的用户集合”,如:sudo 组能用 sudo,audio 组能访问音频,video 组能用 GPU,docker 组能管理容器。Linux 通过把用户加入不同组来决定他们能操作什么。
chmod 用于修改权限:chmod +x a.sh(所有人加执行权限),chmod u+x(给 Owner 加执行权限),chmod g-w(去掉 Group 写权限),chmod o-r(禁掉 Others 读权限)。数字模式如 755、644 表示 r/w/x 的数字和(r=4, w=2, x=1):例如 755 = Owner(rwx) / Group(r-x) / Others(r-x)。
比如创建一个新用户,可以使用sudo adduser <用户名>,授予这个用户sudo权限可以使用sudo usermod -aG sudo <用户名>.
看到这里,李华发觉Linux很多操作都是命令行式的,在终端里面操作的,但李华不知道有那些命令可以使用,于是李华找了一些网站,并尝试了一些常用的命令:
+❯ date
+Sun Nov 16 09:16:15 PM +08 2025
+❯ uname -a
+Linux dos 6.17.7-cachyos #1-NixOS SMP PREEMPT_DYNAMIC Sun Nov 2 13:18:05 UTC 2025 x86_64 GNU/Linux
+❯ uptime
+ 21:16:23 up 4:54, 0 users, load average: 0.79, 0.74, 0.70
+❯ ls
+Data Desktop Documents Downloads Git go Picback Pictures
+❯ cd ./Downloads
+~/Downloads
+
+李华很好奇:这些 ls、cd、uname、date 等命令究竟来自哪里?它们是 Linux 内置的吗?其实,Linux 里的命令大致可以分为三类:Shell 内建命令、外部二进制程序、BusyBox 提供的工具。
cd echo pwd export alias history这些命令不需要执行外部程序,由 Shell 本身的代码直接完成。可以用下面的方式判断命令是否是内建的:type cd
+# cd is a shell builtin
+
+/usr/bin/ls、/usr/bin/date,它们通常来自一个叫 coreutils(GNU Core Utilities) 的软件集合。可以用 which 查看一个命令的真实位置:which ls
+# /usr/bin/ls
+
+这类命令本质上是:ELF 可执行文件/被内核加载/在用户空间运行
+/bin/busybox ls
+/bin/busybox cp
+/bin/busybox tar
+
+随着李华在系统中的探索,李华发现常常遇到诸如Terminal,Console,bash,zsh,shell,tty等概念,这些概念常常被混淆,似乎都和命令行相关,但又不太清楚它们之间是什么关系?
终端,英文叫做 terminal ,通常简称为 term;控制台,英文叫做 console。
+要明白这两者的关系,还得从最初的计算机说起。当时的计算机价格昂贵,一台计算机一般是由多个人同时使用的。在这种情况下一台计算机需要连接上许多套键盘和显示器来供多个人使用。在以前专门有这种可以连上一台电脑的设备,只有显示器和键盘,还有简单的处理电路,本身不具有处理计算机信息的能力,他是负责连接到一台正常的计算机上(通常是通过串口) ,然后登陆计算机,并对该计算机进行操作。当然,那时候的计算机操作系统都是多任务多用户的操作系统。这样一台只有显示器和键盘能够通过串口连接到计算机的设备就叫做终端。
而控制台又是什么回事呢?其概念来自于管风琴的控制台。顾名思义,控制台就是一个直接控制设备的台面(一个面板,上面有很多控制按钮)。 在计算机里,把那套直接连接在电脑上的键盘和显示器就叫做控制台。
终端是通过串口连接上的,不是计算机本身就有的设备,而控制台是计算机本身就有的设备,一个计算机只有一个控制台。计算机启动的时候,所有的信息都会显示到控制台上,而不会显示到终端上。也就是说,控制台是计算机的基本设备,而终端是附加设备。 当然,由于控制台也有终端一样的功能,控制台有时候也被模糊的统称为终端。
以上是控制台和终端的历史遗留区别。现在由于计算机硬件越来越便宜,终端和控制台的概念也慢慢演化了。终端和控制台由硬件的概念,演化成了软件的概念。
内核( Kernel )和外壳( Shell )是 linux 的两个主要部分。Kernel 是操作系统的核心,系统的文件管理、进程管理、内存管理、设备管理这些功能,都是由 Kernel 提供的。
+用户和操作系统内核交流需要一个工具,那么这个工具就是 Shell。
+什么是 Shell?在 Linux 中,最常见的 Shell 形式有命令行界面命令行界面和图形界面两种。并不是打开的那个终端窗口就是 Shell,如Alacritty、Gnome-Terminal、xterm 、kitty等程序,它们不是 Shell,而它们里面运行的 Bash、Zsh、fish 等命令行解释器程序,才是 Shell。
那Alacritty、Gnome-Terminal、xtermxterm是什么?
它们是终端模拟器。
前面提到过,在远古时代,终端和控制台都是有实体的。控制台直接和计算机在一起,你可以通过控制台控制计算机。终端通过数据线和计算机连接,终端也提供一个键盘和一个屏幕,你可以通过键盘向计算机下达指令,然后通过屏幕观察输出。
+但是现在的计算机组成和以前不一样了,一般一台电脑都是自带键盘和屏幕,很少再外接终端设备。
+所以 Linux 提供了另外一个更高级的功能,那就是虚拟终端。那就是在一台电脑上,通过软件的模拟,好像有好几个终端连接在这台计算机上一样。
+现在说的终端,比如 linux 中的虚拟终端,都是软件的概念。虚拟终端称之为 tty,tty 是电传打字机电传打字机 Teletypewriter 的缩写,在带显示屏的视频终端出现之前,tty是最流行的终端设备。每一个 tty 都有一个编号,在/dev目录下有相应的设备文件。其中/dev/tty1到/dev/tty7可以通过 Ctrl+Alt+F1 到 Ctrl+Alt+F7 进行切换,也可以通过 chvt 命令进行切换,就好比是以前多人公用的计算机中的六个终端设备,这就是为什么这个叫“虚拟终端”的原因。
++如果你现在使用linux,可以使用Ctrl+Alt+F2切换到TTY界面!
+
在 Windows 上,图形界面是系统密不可分的一部分。但李华发现,他安装的 Ubuntu 界面叫 GNOME,而他同学安装的 Mint 界面却是 Cinnamon,而且他听说还有 KDE、XFCE 等等,这让他感到困惑。
+在 Linux 中,图形界面是可以高度定制和替换的。它主要由以下几个核心组件构成:
桌面环境(DE) 是一整套完整的、提供图形化操作体验的软件集合。它包括了:
+窗口管理器(Window Manager, WM):负责绘制窗口边框、最大化/最小化按钮、控制窗口的移动和堆叠。
+文件管理器:如 Nautilus (GNOME)、Dolphin (KDE)。
+面板/任务栏:提供应用启动器、系统托盘、时钟等。
+显示管理器(Display Manager, DM):负责登录界面(如 GDM, LightDM)。
+一系列配套应用:如文本编辑器、图片查看器等。
+
+窗口管理器(WM) 是 DE 的核心组件之一,但也可以独立运行。如果你不需要一个完整的桌面环境(如文件管理器、面板等),只想要管理窗口的显示和布局,就可以只安装一个 WM。
+| 常见 DE | 常见 WM |
|---|---|
| KDE | i3 |
| Xfce | niri |
| Gnome | qtile |
| — | bspwm |
| — | Hyprland |
| — | awesomewm |
无论是 DE 还是 WM,它们都需要一套机制来告诉应用程序“在哪里绘制一个按钮”、“如何响应鼠标点击”等。这就是 图形显示协议。
+++对于新手,建议直接使用主流发行版的默认 DE(如 Ubuntu 的 GNOME 或 CachyOS 的 KDE),它们都提供了完整的用户体验。如果你是开发者或极客,可以尝试平铺式 WM,并关注 Wayland 的发展。
+
李华在折腾 GNOME 桌面时,发现很多配置文件夹都藏在 ~/.config 下,而缓存文件在 ~/.cache,下载的应用数据却在 ~/.local/share。他发现这比 Windows 时代全部扔在 C:\Users\username\AppData 里规范多了!
这套规范就是 XDG 基础目录规范(XDG Base Directory Specification),它是 Freedesktop.org(一个致力于桌面环境互操作性的组织)推广的一项标准。
+XDG 规范的核心思想是将用户的文件按照用途分离,而不是像 Windows 那样把所有数据都塞进一个 AppData 文件夹。
| 环境变量/目录 | 默认路径(若未设置) | 用途 |
|---|---|---|
$XDG_CONFIG_HOME | ~/.config | 存放用户配置文件(Configuration files)。 |
$XDG_CACHE_HOME | ~/.cache | 存放非关键的缓存文件(Cache files),可以随时删除。 |
$XDG_DATA_HOME | ~/.local/share | 存放应用程序生成的用户数据(Data files),如游戏存档、下载的图标等。 |
$XDG_RUNTIME_DIR | 通常是 /run/user/$(id -u) | 存放运行时文件,生命周期与用户登录会话一致,重启或注销后消失。 |
通过遵守 XDG 规范,可以带来很多好处:
+$XDG_CACHE_HOME 下的文件即可,不会误删配置。$XDG_CONFIG_HOME 就可以保留所有应用程序的配置。对于想在 Linux 上进行开发的李华来说,Linux 简直是为开发而生的系统。由于其开源、类 UNIX 的特性,它在软件开发领域拥有巨大的优势。
+Linux 默认提供了强大的 GNU 工具链:
+在 Windows 上,安装 Python 或 Node.js 往往需要下载安装包并手动设置环境变量,管理多版本很麻烦。在 Linux 上,这变得非常优雅:
+apt 或 pacman 安装主流编程语言及其依赖。pyenvnvmgvmrvm / rbenvLinux 的内核天然支持 Cgroups 和 Namespaces,这是 Docker 和 Kubernetes 等容器化技术的基础。
+Done.
+ +前言 本文基于常见发行版(systemd + NetworkManager + PipeWire/ PulseAudio / ALSA),目标是把常见的桌面/笔记本硬件(Wi-Fi、蓝牙、亮度、音量)通过命令行可复现、可理解地组织起来。
+现代桌面大多使用 NetworkManager 管理网络,nmcli 是其命令行接口。nmcli 能列出可用网络、连接/断开、创建配置文件(包括 WPA/WPA2/PSK、enterprise)等。相比直接编辑 wpa_supplicant 配置,nmcli 更安全、统一,能与 GUI 保持一致。
列出接口及设备状态:
+nmcli device status
+
+列出附近 Wi-Fi(SSID、信号强度、安全类型):
+nmcli device wifi list
+
+交互式连接(会提示输入密码):
+nmcli device wifi connect "wifi-2.4G" --ask
+
+不交互式连接(将密码放在命令里 — 注意安全风险):
+nmcli device wifi connect "wifi-2.4G" password "your_password"
+
+基于已有配置文件连接(例如创建一个保存的 connection 名称):
+# 创建连接(自动选择设备)
+nmcli connection add type wifi ifname wlan0 con-name my-home ssid "wifi-2.4G" \
+ wifi-sec.key-mgmt wpa-psk wifi-sec.psk "your_password"
+
+# 启用连接
+nmcli connection up my-home
+
+断开或禁用接口:
+# 断开当前连接
+nmcli device disconnect wlan0
+
+# 禁用设备(软禁用)
+nmcli device set wlan0 managed no
+
+查看连接详情:
+nmcli -f all connection show my-home
+nmcli device show wlan0
+
+Linux 上常见蓝牙栈为 BlueZ(蓝牙守护 bluetoothd),bluetoothctl 提供交互式 CLI。音频设备通常通过 BlueZ + PulseAudio(或 PipeWire)进行音频路由;配对/信任步骤必须完成才能稳定连接音频/键盘/鼠标等设备。
启用蓝牙服务(systemd):
+sudo systemctl enable --now bluetooth.service
+
+打开蓝牙适配器电源:
+bluetoothctl power on
+
+打开配对代理(用于交互式配对)并设置为默认:
+bluetoothctl agent on
+bluetoothctl default-agent
+
+开启可发现(让其它设备能扫描到):
+bluetoothctl discoverable on
+
+重启蓝牙服务(排错常用):
+sudo systemctl restart bluetooth
+sudo journalctl -u bluetooth -f
+
+++注意:某些发行版在使用 PipeWire 做音频时还需要
+pipewire/wireplumber正确运行,否则音频通道(A2DP/HFP)无法建立。
# 列出本机所有蓝牙适配器
+bluetoothctl list
+
+# 查看本地适配器详细状态
+bluetoothctl show
+
+# 查看已配对设备
+bluetoothctl paired-devices
+
+# 查看某个设备详情(包括 UUID、已连接服务)
+bluetoothctl info AA:BB:CC:DD:EE:FF
+
+交互式步骤(在 bluetoothctl 提示符下):
$ bluetoothctl
+[bluetooth]# power on
+[bluetooth]# agent on
+[bluetooth]# default-agent
+[bluetooth]# scan on
+# 等待几秒,看到目标设备(并记录 MAC)
+[bluetooth]# pair AA:BB:CC:DD:EE:FF
+# 如果是需要 PIN 的设备,会提示配对码;确认或输入即可
+[bluetooth]# trust AA:BB:CC:DD:EE:FF # 使系统信任设备(开机后自动连接)
+[bluetooth]# connect AA:BB:CC:DD:EE:FF
+[bluetooth]# exit
+
+断开连接:
+bluetoothctl disconnect AA:BB:CC:DD:EE:FF
+
+删除配对信息(“忘记设备”):
+bluetoothctl remove AA:BB:CC:DD:EE:FF
+
+查看封锁状态:
+rfkill list bluetooth
+
+封锁(禁用):
+sudo rfkill block bluetooth
+
+解封(启用):
+sudo rfkill unblock bluetooth
+
+如果设备被硬封锁(硬件开关),软件方法无效,需要物理开关或 BIOS 设置。
+pactl(PulseAudio 控制工具)在很多系统仍然可用。bluez_output.XX_XX_XX_XX_XX_XX.a2dp_sink 的 sink 名称;有时名称会略有差异,建议先查询。列出 sinks(输出设备):
+pactl list short sinks
+
+设置默认输出为蓝牙耳机(示例):
+pactl set-default-sink bluez_output.XX_XX_XX_XX_XX_XX.a2dp_sink
+
+把当前正在播放的流移动到蓝牙设备:
+pactl list short sink-inputs # 找到输入编号
+pactl move-sink-input <输入编号> bluez_output.XX_XX_XX_XX_XX_XX.a2dp_sink
+
+如果使用 PipeWire,遇到连接但没有声音的问题:
+wireplumber 或 pipewire-media-session 正常运行。pactl list cards / pactl set-card-profile 调整。笔记本屏幕亮度通常由内核暴露的 SysFS 接口 /sys/class/backlight/*/brightness 提供,写入该文件需要 root 权限或合适的权限(udev 规则)。桌面显示器、USB 显卡或 Wayland(特别是 wlroots)环境可能不会使用该接口,需要使用专门工具(如 light、brightnessctl、或 DE/Compositor 提供的接口)。
查看最大亮度值与当前亮度:
+cat /sys/class/backlight/*/max_brightness
+cat /sys/class/backlight/*/brightness
+
+设置亮度(需要 root):
+# 写入数值(0~max_brightness)
+echo 5 | sudo tee /sys/class/backlight/*/brightness
+
+# 或者重定向(注意 sudo 的作用域)
+sudo sh -c 'echo 5 > /sys/class/backlight/*/brightness'
+
+如果遇到 “权限被拒绝”:
+sudo tee 或 sudo sh -c;或添加 udev 规则给某个用户写权限。intel_backlight、amdgpu_bl0 等)。brightnessctl 是一个用户友好、支持百分比与设备选择的工具。
安装:
+sudo apt install brightnessctl
+
+sudo pacman -S brightnessctl
+
+用法示例:
+brightnessctl info # 显示当前设备信息
+brightnessctl get # 当前亮度
+brightnessctl max # 最大亮度
+brightnessctl set +10% # 增加 10%
+brightnessctl set 50% # 设为 50%
+
+Linux 下有几层音量控制:硬件(ALSA)、中间层(PulseAudio / PipeWire)、用户层(桌面音量控制器)。常用命令行工具:pactl(PulseAudio / PipeWire)、pamixer(PulseAudio 前端)、amixer(ALSA 原生)。
查看 sinks:
+pactl list short sinks
+
+查看默认 sink:
+pactl info | grep 'Default Sink'
+
+设置默认音量:
+pactl set-sink-volume @DEFAULT_SINK@ 50%
+
+增量调节:
+pactl set-sink-volume @DEFAULT_SINK@ +5%
+pactl set-sink-volume @DEFAULT_SINK@ -5%
+
+静音/取消静音/切换:
+pactl set-sink-mute @DEFAULT_SINK@ 1
+pactl set-sink-mute @DEFAULT_SINK@ 0
+pactl set-sink-mute @DEFAULT_SINK@ toggle
+
+移动播放流(见蓝牙章节):
+pactl list short sink-inputs
+pactl move-sink-input <输入编号> <目标-sink>
+
+列出通道与当前值:
+amixer sget Master
+
+设置音量(绝对 / 相对):
+amixer sset Master 50% # 绝对值
+amixer sset Master 5%+ # 增加
+amixer sset Master 5%- # 减少
+
+静音:
+amixer set Master mute
+amixer set Master unmute
+amixer set Master toggle
+
+++当使用 PipeWire/PulseAudio 时,
+amixer仍然可以操作底层硬件,但用户可听到的效果可能被上层音量(PulseWire/PulseAudio)覆盖。
简洁的命令行前端,适合脚本:
+pamixer --get-volume
+pamixer --set-volume 40
+pamixer --increase 5
+pamixer --decrease 5
+pamixer --toggle-mute
+
+Done.
+ +前言 本文记录STM32命令行开发环境在Linux上的部署,用以替代Windows上的RT-Thread-studio。RT-Thread-studio同样是开源 +软件,但目前没有Nixos上的打包。
+以ubuntu24.04为例,首先安装这些包,包括连接工具,工具链和调试器等等。
+sudo apt update
+sudo apt install -y git python3 scons openocd stlink-tools gcc-arm-none-eabi gdb-multiarch
+
+虽然Nixos上没有RT-Thread-studio这个包,但是可以用flake.nix很方便的搭建一个开发环境:
+{
+ description = "STM32 && RT-Thread development environment";
+ inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
+ outputs = { self, nixpkgs }:
+ let
+ supportedSystems = [ "x86_64-linux" "aarch64-linux" ];
+ forEachSupportedSystem = f: nixpkgs.lib.genAttrs supportedSystems (system: f {
+ pkgs = import nixpkgs { inherit self system; };
+ });
+ in
+ {
+ devShells = forEachSupportedSystem ({ pkgs }: {
+ default = pkgs.mkShell {
+ packages = with pkgs; [
+ python312
+ scons
+ openocd
+ stlink
+ stlink-tool
+ gcc-arm-embedded
+ picocom
+ renode-bin
+ ];
+ };
+ });
+ };
+}
+
+随后使用Git拉取项目源码:
+git clone https://github.com/RT-Thread-Studio/sdk-bsp-stm32f407-spark.git
+
+使用Git拉取RT-Thread配套的linux开发环境,并添加Shell变量。
+# 克隆仓库
+git clone https://github.com/RT-Thread/env.git ~/env
+# 将 ~/env 添加到 PATH
+export PATH="$PATH:$HOME/env"
+# 显示 PATH
+echo "$PATH"
+# 查看 pkgs 命令是否存在
+type pkgs
+
+随后可以使用PKG初始化并安装两个必要的包:
+pkgs --update
+pip install kconfiglib
+pip install scons
+
+使用USB线连接开发板和开发PC,并使用lsusb命令查看是否出现:
+lsusb
+Bus 001 Device 004: ID 0483:374b STMicroelectronics ST-LINK/V2.1
+
+添加成功后可以使用这个命令来检测是否连接成功:
+❯ st-info --probe
+Found 1 stlink programmers
+ version: V2J35S26
+ serial: 0671FF373654393143244522
+ flash: 1048576 (pagesize: 16384)
+ sram: 196608
+ chipid: 0x413
+ dev-type: STM32F4x5_F4x7
+
+++如果你和我一样将Ubuntu安装在QEMU虚拟机中 ,需要在libvirt中使用Add_hardware添加usb设备。
+
链接成功后进入项目目录,发现rtconfig.py没有Linux路径,需要我们手动修改交叉工具链部分:
#修改 rtconfig.py
+
+# cross_tool provides the cross compiler
+# EXEC_PATH is the compiler execute path, for example, CodeSourcery, Keil MDK, IAR
+import os
+
+if CROSS_TOOL == 'gcc':
+ PLATFORM = 'gcc'
+ if os.name == 'nt':
+ # Windows 平台
+ EXEC_PATH = r'C:\Users\XXYYZZ'
+ else:
+ # 修改这里
+ # Linux / macOS 平台
+ EXEC_PATH = '/usr/bin'
+
+elif CROSS_TOOL == 'keil':
+ PLATFORM = 'armclang' # KEIL AC6
+ # PLATFORM = 'armcc' # KEIL AC5
+ EXEC_PATH = r'C:/Keil_v5'
+
+elif CROSS_TOOL == 'iar':
+ PLATFORM = 'iccarm'
+ EXEC_PATH = r'C:/Program Files (x86)/IAR Systems/Embedded Workbench 8.3'
+
+elif CROSS_TOOL == 'llvm-arm':
+ PLATFORM = 'llvm-arm'
+ if os.name == 'nt':
+ EXEC_PATH = r'D:\Progrem\LLVMEmbeddedToolchainForArm-17.0.1-Windows-x86_64\bin'
+ else:
+ EXEC_PATH = '/usr/bin'
+
+在完成以上设置之后我们可以开始编译。STM32使用scons编译系统,同样是menuconfig命令:
+scons --menuconfig
+
+修改配置并保存退出后即可开始编译,$(nproc)代表使用全部CPU线程来编译:
+scons -j$(nproc)
+
+编译成功后你应该会看到有一个rtthread.bin在目录下,这就是我们编译出来的系统!
+在烧入之前,我们可以备份一下原来的系统:
+st-flash read firmware_backup.bin 0x08000000 0x100001
+
+随后使用如下命令烧入系统:
+st-flash write rtthread.bin 0x08000000
+
+除了USB之外我们还可以使用串口连接:
+sudo apt install picocom
+picocom -b 115200 /dev/ttyACM0
+
+可以使用ctrl + A 然后 ctrl + x退出。
通过官方文档可以得知除了scons外还可以使用Cmake来编译.
+首先找到编译器的路径,并export,我这里是Nixos的路径,如果你使用其他发行版注意修改:
+❯ which arm-none-eabi-gcc
+/nix/store/v9p5md3d4aaqwc9i9hlaxkl7nawd9vrc-gcc-arm-embedded-14.3.rel1/bin/arm-none-eabi-gcc
+export RTT_EXEC_PATH=/nix/store/v9p5md3d4aaqwc9i9hlaxkl7nawd9vrc-gcc-arm-embedded-14.3.rel1/bin
+export RTT_CC=gcc
+
+随后使用指令scons --target=cmake:
❯ scons --target=cmake
+
+scons: Reading SConscript files ...
+Newlib version:4.5.0
+Update setting files for CMakeLists.txt...
+Done!
+scons: done reading SConscript files.
+scons: Building targets ...
+scons: building associated VariantDir targets: build
+CC build/applications/main.o
+LINK rt-thread.elf
+arm-none-eabi-objcopy -O binary rt-thread.elf rtthread.bin
+arm-none-eabi-size rt-thread.elf
+scons: done building targets.
+
+可以看到生成CmakeLists.txt成功,随后开始构建:
+❯ cd ./build
+❯ cmake ..
+CMake Warning (dev) at CMakeLists.txt:43:
+ Syntax Warning in cmake code at column 100
+
+ Argument not separated from preceding token by whitespace.
+This warning is for project developers. Use -Wno-dev to suppress it.
+
+-- The C compiler identification is GNU 14.3.1
+-- The CXX compiler identification is GNU 14.3.1
+-- The ASM compiler identification is GNU
+-- Found assembler: /nix/store/v9p5md3d4aaqwc9i9hlaxkl7nawd9vrc-gcc-arm-embedded-14.3.rel1/bin/arm-none-eabi-gcc
+-- Detecting C compiler ABI info
+-- Detecting C compiler ABI info - done
+-- Check for working C compiler: /nix/store/v9p5md3d4aaqwc9i9hlaxkl7nawd9vrc-gcc-arm-embedded-14.3.rel1/bin/arm-none-eabi-gcc - skipped
+-- Detecting C compile features
+-- Detecting C compile features - done
+-- Detecting CXX compiler ABI info
+-- Detecting CXX compiler ABI info - done
+-- Check for working CXX compiler: /nix/store/v9p5md3d4aaqwc9i9hlaxkl7nawd9vrc-gcc-arm-embedded-14.3.rel1/bin/arm-none-eabi-g++ - skipped
+-- Detecting CXX compile features
+-- Detecting CXX compile features - done
+-- Configuring done (0.4s)
+-- Generating done (0.0s)
+-- Build files have been written to: /home/dich/Git/sdk-bsp-stm32f407-spark/projects/02_basic_ir/build
+
+使用make命令编译:
❯ make
+[ 1%] Building C object CMakeFiles/rtthread.elf.dir/applications/main.c.obj
+[ 2%] Building C object CMakeFiles/rtthread.elf.dir/home/dich/Git/sdk-bsp-stm32f407-spark/rt-thread/components/libc/compilers/common/cctype.c.obj
+[ 3%] Building C object CMakeFiles/rtthread.elf.dir/home/dich/Git/sdk-bsp-stm32f407-spark/rt-thread/components/libc/compilers/common/cstdio.c.obj
+......
+[ 97%] Building C object CMakeFiles/rtthread.elf.dir/home/dich/Git/sdk-bsp-stm32f407-spark/libraries/STM32F4xx_HAL/STM32F4xx_HAL_Driver/Src/stm32f4xx_hal_tim.c.obj
+[ 98%] Building C object CMakeFiles/rtthread.elf.dir/home/dich/Git/sdk-bsp-stm32f407-spark/libraries/STM32F4xx_HAL/CMSIS/Device/ST/STM32F4xx/Source/Templates/system_stm32f4xx.c.obj
+[100%] Linking C executable rtthread.elf
+ text data bss dec hex filename
+ 98516 1468 8400 108384 1a760 rtthread.elf
+[100%] Built target rtthread.elf
+
+如果没有真实的开发版,可以使用Renode来进行仿真模拟:
+# 启动renode
+renode
+
+# 创建机器
+(monitor) mach create
+
+# 加载STM32F407平台
+(monitor) machine LoadPlatformDescription @platforms/boards/stm32f4_discovery.repl
+
+# 加载你的固件
+(monitor) sysbus LoadELF @/你的路径/rtthread.elf
+
+# 打开串口窗口(finsh会显示在这里)
+(monitor) showAnalyzer sysbus.usart1
+
+# 启动仿真
+(monitor) start
+
+++Renode 常用命令大全
+
# 机器管理
+mach add "名称" # 创建新机器(指定名称)
+mach create # 创建新机器(自动命名)
+mach set "名称" # 切换到指定机器
+mach set 0 # 切换到编号0的机器
+mach rem "名称" # 删除机器
+mach clear # 清除当前选择
+mach # 显示帮助信息
+emulation # 查看仿真信息
+
+# 仿真控制
+start # 启动仿真
+pause # 暂停仿真
+quit # 退出Renode
+
+# 帮助
+help # 显示帮助
+help 命令名 # 查看特定命令帮助
+
+# 加载固件
+sysbus LoadELF @/path/to/firmware.elf # 加载ELF文件
+sysbus LoadBinary @/path/to/firmware.bin 0x8000000 # 加载BIN到指定地址
+
+# 重置
+sysbus Reset # 重置系统总线
+machine Reset # 重置整个机器
+
+# 读取内存
+sysbus ReadByte 0x20000000 # 读1字节
+sysbus ReadWord 0x20000000 # 读2字节
+sysbus ReadDoubleWord 0x20000000 # 读4字节
+
+# 写入内存
+sysbus WriteByte 0x20000000 0xFF
+sysbus WriteWord 0x20000000 0x1234
+sysbus WriteDoubleWord 0x20000000 0x12345678
+
+# 查看内存区域
+sysbus FindSymbolAt 0x08000000 # 查找地址对应的符号
+
+# 查看GPIO端口
+sysbus.gpioPortA
+
+# 设置GPIO状态
+sysbus.gpioPortA.0 Set true # 设置PA0为高
+sysbus.gpioPortA.0 Set false # 设置PA0为低
+sysbus.gpioPortA.0 Toggle # 切换PA0状态
+
+# 读取GPIO状态
+sysbus.gpioPortA.0 State
+
+# 使用GDB调试
+(monitor) machine StartGdbServer 3333
+# 另一个终端
+arm-none-eabi-gdb firmware.elf
+(gdb) target remote :3333
+(gdb) load
+(gdb) b main
+(gdb) c
+
+Done.
+ +前言 本文记录Android命令行开发环境在Linux上的部署,用以替代Android-studio。
+sudo apt install openjdk-17-jdk nodejs
+
+mkdir -p ~/Android/cmdline-tools/latest
+## 下载链接:https://developer.android.com/studio?hl=zh-cn#command-tools
+cd ~/Android/cmdline-tools/latest
+wget https://dl.google.com/android/repository/commandlinetools-linux-13114758_latest.zip
+unzip ./commandlinetools-linux-13114758_latest.zip
+
+curl -s "https://get.sdkman.io" | bash
+source "$HOME/.sdkman/bin/sdkman-init.sh"
+
+sdk install gradle
+sdk install kotlin
+
+export ANDROID_HOME=$HOME/Android
+export PATH=$PATH:$ANDROID_HOME/emulator
+export PATH=$PATH:$ANDROID_HOME/platform-tools
+export PATH=$PATH:$ANDROID_HOME/cmdline-tools/latest/bin
+export PATH=$PATH:$ANDROID_HOME/build-tools/34.0.0
+source ~/.bashrc
+
+sdkmanager "platforms;android-34" "build-tools;34.0.0" "platform-tools"
+sdkmanager "emulator" //虚拟机中调试
+
+(base) dich@uos:~$ sdk version
+
+SDKMAN!
+script: 5.20.0
+native: 0.7.14 (linux x86_64)
+
+(base) dich@uos:~$ gradle -v
+
+------------------------------------------------------------
+Gradle 8.10.2
+------------------------------------------------------------
+
+Build time: 2024-09-23 21:28:39 UTC
+Revision: 415adb9e06a516c44b391edff552fd42139443f7
+
+Kotlin: 1.9.24
+Groovy: 3.0.22
+Ant: Apache Ant(TM) version 1.10.14 compiled on August 16 2023
+Launcher JVM: 17.0.16 (Ubuntu 17.0.16+8-Ubuntu-0ubuntu124.04.1)
+Daemon JVM: /usr/lib/jvm/java-17-openjdk-amd64 (no JDK specified, using current Java home)
+OS: Linux 6.14.0-35-generic amd64
+
+(base) dich@uos:~/Git/android-templates$ kotlin -version
+Kotlin version 1.6.21-release-334 (JRE 21.0.8+9-Ubuntu-0ubuntu124.04.1)
+(base) dich@uos:~/Git/android-templates/template-compose$ kscript -v
+Copyright : 2022 Holger Brandl
+License : MIT
+Version : v4.0.3
+Website : https://github.com/holgerbrandl/kscript
+A new version (v4.2.0) of kscript is available.
+Kotlin : 2.1.10-release-473
+Java : JRE 17.0.16+8
+
+构建Release包需要密钥签名验证,可以使用传统的明文配置或者使用密钥管理器.
+keytool -genkey -v \
+ -keystore ~/.android/jetlagged-release.keystore \
+ -alias jetlagged \
+ -keyalg RSA \
+ -keysize 2048 \
+ -validity 10000
+
+ signingConfigs {
+ create("release") {
+ storeFile = System.getenv("KEYSTORE_FILE")?.let { file(it) }
+ storePassword = System.getenv("KEYSTORE_PASSWORD")
+ keyAlias = System.getenv("KEY_ALIAS")
+ keyPassword = System.getenv("KEY_PASSWORD")
+ }
+ }
+
+ buildTypes {
+ release {
+ signingConfig = signingConfigs.getByName("release") // 添加这行
+ isMinifyEnabled = true
+ proguardFiles(
+ getDefaultProguardFile("proguard-android-optimize.txt"),
+ "proguard-rules.pro"
+ )
+ }
+ }
+
+cat > ~/.android-signing-secrets << 'EOF'
+export KEYSTORE_FILE="$HOME/.android/jetlagged-release.keystore"
+export KEYSTORE_PASSWORD="你的keystore密码"
+export KEY_ALIAS="jetlagged"
+export KEY_PASSWORD="你的key密码"
+EOF
+
+# 设置权限
+chmod 600 ~/.android-signing-secrets
+
+# 添加到 gitignore (全局)
+echo ".android-signing-secrets" >> ~/.gitignore_global
+
+# Auto load Key
+if [ -f "$HOME/.android-signing-secrets" ]; then
+ source "$HOME/.android-signing-secrets"
+ echo "KeyOK"
+fi
+
+android_key_password和android_keystore_password;name/android_key_password和name/android_keystore_password;# Release Key
+export KEYSTORE_FILE="$HOME/.android/jetlagged-release.keystore"
+export KEY_ALIAS="jetlagged"
+export KEYSTORE_PASSWORD="$(secret-tool lookup name android_keystore_password)"
+export KEY_PASSWORD="$(secret-tool lookup name android_key_password)"
+
+Done.
+ +前言 Aria2是一款开源、跨平台的命令行界面下载管理器,常常被各种下载器软件使用。
+在上网的时候,我们可能需要下载一些东西,而浏览器自带的下载比较缓慢。为此,许多人安装了类似IDM或者Motrix等等软件,用多线程来加速下载。其实,许多开源的下载器就是Aria2的前端,我们可以直接使用Aria2进行下载。
+Aria2是一款开源、跨平台的命令行界面下载管理器,支持的下载协议有:HTTP、HTTPS、FTP、Bittorrent 和 Metalink。它以高效、轻量和灵活著称,适用于需要批量下载、自动化任务或远程控制的用户。
Aria2 有以下几个特点:
+多连接下载:可以从多个来源/协议下载文件并尝试利用您的最大下载带宽,真正加快您的下载体验;轻量:不需要太多内存和 CPU 时间;全功能的 BitTorrent 客户端:BitTorrent 客户端的所有功能都可用,,如 DHT、PEX、加密、Magnet URI、网络播种、选择性下载、本地对等发现和 UDP 跟踪器;支持Metalink:支持 Metalink 下载描述格式。 在下载中使用 Metalink 数据块的校验和自动验证下载的数据部分;远程控制:支持 RPC 接口来控制 aria2 进程。 支持的接口是 JSON-RPC(通过 HTTP 和 WebSocket)和 XML-RPC。要使用Aria2来替代浏览器自带的下载,一般需要三个条件:
+首先下载aria2-1.37.0-win-64bit-build1.zip,将下载好的文件解压并放到你喜欢的目录下,设置系统环境变量,类似D:\DATA\Data\AriaNg-1.3.10-AllInOne,随后即可在 CMD 中使用aria2c -v查看Aria2 。
然后创建一个配置文件C:\Users\<你>\.aria2\aria2.conf,内容如下:
# 下载目录
+dir=C:/Users/<你>/Downloads
+
+# 断点续传
+continue=true
+file-allocation=prealloc
+
+# RPC 设置
+enable-rpc=true
+rpc-listen-all=true
+rpc-allow-origin-all=true
+rpc-listen-port=6800
+rpc-secret=<你的密码>
+
+随后在这个项目中winsw下载 WinSW-x64.exe到一个目录,并重命名为 aria2-service.exe,并在同目录下创建aria2-service.xml,内容如下:
<service>
+ <id>aria2</id>
+ <name>Aria2 Service</name>
+ <description>Aria2 Download Manager</description>
+ <executable>C:\Users\<你>\scoop\apps\aria2\current\aria2c.exe</executable>
+ <arguments>--conf-path=C:\Users\<你>\.aria2\aria2.conf</arguments>
+</service>
+
+随后使用.\aria2-service.exe install安装服务,并使用.\aria2-service.exe start启动服务,类似linux上的systemctl.
++注意修改用户名!
+
Arch linux 和大部分常规发行版可以适用此方法。
+首先安装aria2本体:
+paru -S aria2
+
+随后创建配置文件
+nano /home/<you-username>/.config/aria2/aria2.conf
+
+内容为
+enable-rpc=true
+rpc-listen-all=true
+rpc-allow-origin-all=true
+rpc-listen-port=6800
+continue=true
+dir=/home/<you-username>/Downloads
+input-file=/home/<you-username>/.config/aria2/aria2.session
+save-session=/home/<you-username>/.config/aria2/aria2.session
+save-session-interval=60
+
+保存退出;随后创建守护进程以便开机自启动:
+nano ~/.config/systemd/user/aria2.service
+
+写入:
+[Unit]
+Description=Aria2 Daemon
+After=network.target
+
+[Service]
+ExecStart=/usr/bin/aria2c --conf-path=/home/<you-username>/.config/aria2/aria2.conf
+Restart=on-failure
+
+[Install]
+WantedBy=default.target
+
+在更新配置文件和服务文件后,执行以下命令以重启服务:
+systemctl --user daemon-reload
+systemctl --user enable aria2.service
+systemctl --user start aria2.service
+
+使用以下命令检查服务状态:
+systemctl --user status aria2.service
+
+{ lib, pkgs, username, ... }:
+{
+ services.aria2.enable = false;
+ systemd.services.aria2 = {
+ description = "Aria2 Download Manager (dich)";
+ after = [ "network.target" ];
+ wants = [ "network.target" ];
+ wantedBy = [ "multi-user.target" ];
+
+ serviceConfig = {
+ Type = "simple";
+ User = username;
+
+ ExecStartPre = [
+ "${pkgs.coreutils}/bin/mkdir -p /home/${username}/.config/aria2"
+ "${pkgs.coreutils}/bin/touch /home/${username}/.config/aria2/aria2.session"
+ ];
+
+ ExecStart = "${pkgs.aria2}/bin/aria2c --conf-path=/home/${username}/.config/aria2/aria2.conf";
+
+ Restart = "always";
+ RestartSec = "5s";
+
+ NoNewPrivileges = true;
+ PrivateTmp = true;
+ };
+ };
+}
+
+如果你不想用浏览器插件或者面板,也可以直接使用命令行操作:
+aria2c [选项] [URL | 磁力链接 | .torrent文件]
+
+aria2c https://example.com/file.iso
+
+aria2c -d ~/Downloads -o ubuntu.iso https://releases.ubuntu.com/24.04/ubuntu.iso
+
+aria2c https://example.com/file1.zip https://example.com/file2.zip
+
+aria2c -i urls.txt
+
+(urls.txt 每行一个链接)
aria2c ubuntu.torrent
+
+aria2c "magnet:?xt=urn:btih:xxxxx..."
+
+aria2c --max-upload-limit=50K ubuntu.torrent
+
+如果你想让其直接接管浏览器下载,可以使用以下几种浏览器插件,它们都自带面板:
+Chrome 浏览器
+Firefox 浏览器
+++注意!如果你前面配置中设置了rpc的密码,需要在面板中也写入才可连接成功。
+

如果你不想使用浏览器插件,也可以使用aria2+独立面板的方法,但这样就不能接管浏览器的下载,适合其他环境使用。
+这里推荐使用 AriaNg 前端,AriaNg 使用纯 html & javascript 开发, 所以其不需要任何编译器或运行环境.
+
AriaNg 现在提供三种版本, 标准版、单文件版和 AriaNg Native. 标准版适合在 Web 服务器中部署, 提供资源缓存和按需加载的功能. 单文件版适合本地使用, 您下载后只要在浏览器中打开唯一的 html 文件即可. AriaNg Native 同样适合本地使用, 并且不需要使用浏览器.这里建议使用单文件版或者Native版,下之后打开其中的html并设为书签即可。
Done.
+ +前言 内容分发网络(CDN)是一组分布在不同地理位置的服务器网络,使用户能够就近获取内容,从而降低延迟并缓解源站压力.
+内容分发网络(CDN)是一组分布在不同地理位置的服务器网络,旨在将网站或应用的静态资源(如HTML、图片、视频等)缓存到距离用户更近的节点,以缩短传输路径、降低带宽成本并提高访问速度.CDN通过“缓存”机制,在全球多个数据中心临时存储内容副本,用户发起请求时无需回源到主服务器,就能从最近的缓存节点获取数据,从而显著改善页面加载时间和整体用户体验.相比传统的单点源站访问,CDN在用户和源站之间增加了分层缓存,通过负载均衡技术和智能路由,将访问请求定向到最优节点,既减轻了源站压力,又提升了网络抗拥塞能力和可用性.
+在现代互联网中,内容分发网络(CDN)和域名系统(DNS)相互配合,共同提升了网页和多媒体内容的访问速度与可靠性.CDN通过在全球分布的缓存节点上存储静态资源,使用户能够就近获取内容,从而降低延迟并缓解源站压力.而DNS则负责将用户的域名请求导向适当的CDN节点,通过CNAME重定向、全局负载均衡(GSLB)、Anycast及EDNS扩展等技术,实现智能化的流量调度和最优路径选择.
+CDN的核心功能与优势
+加速访问:将内容存储于距离用户更近的节点,减少传输延迟,常见于视频点播、大文件下载等场景.
+减轻源站压力:缓存请求可直接由CDN节点响应,降低源站带宽和计算资源消耗,有助于应对突发流量和DDoS攻击.
+高可用与弹性扩展:全球分布的节点架构,使内容分发具备冗余能力,单点故障不会影响整体服务,且可动态扩容以应对业务增长.
+当用户在浏览器中输入域名发起请求时,首先触发本地DNS解析过程;如果该域名已开通CDN服务,其DNS解析记录通常配置为一条CNAME(别名)记录,指向CDN运营商提供的专用域名;本地DNS服务器再将解析权交给CDN的权威DNS服务器,从而实现对CDN网络的接入.
+CDN的权威DNS服务器根据用户请求的域名,返回一个“全局负载均衡设备”的IP地址,该IP并非最终缓存节点,而是GSLB层用于智能调度的入口地址;浏览器接收到该IP后,向GSLB层发起实际内容请求.
+GSLB(Global Server Load Balancing)是CDN架构中最核心的部分,负责根据多种因素(用户IP地理位置、节点健康状态、节点负载情况等)动态选择最优区域负载均衡节点或缓存服务器,向用户提供最低延迟和最佳性能的服务.
+这一过程通常也基于DNS解析完成:当GSLB层接到DNS查询请求时,智能DNS服务器会返回针对该用户最优的缓存节点IP,从而实现“DNS级”的流量调度和负载均衡.
+Anycast路由:部分CDN运营商在全球部署相同IP的多个节点,利用BGP Anycast技术使得用户请求自动路由到网络拓扑上“最近”的节点,增强访问的网络路径效率与容灾能力.
+EDNS Client Subnet(EDNS-CS):传统DNS仅看到发起查询的递归DNS服务器IP,难以准确判断终端用户位置;EDNS-CS协议在DNS请求中携带部分客户端IP前缀,使权威DNS能更细粒度地进行地理定位与节点选取,大幅提升了基于DNS的智能调度精度.
+++在启用 CDN 后,终端用户看到的并不是您在源站(origin)上配置的自签名证书,而是 CDN 边缘节点(edge)所出示的、由受信任 CA 签发的“边缘证书”.也就是说,浏览器与 CDN 边缘之间的 TLS 握手完全独立于您源站和自签名证书的存在,源站的自签名证书仅用于 CDN 与源站之间的“后端”加密连接,不会暴露给最终用户浏览器.
+
CDN 模式下的 TLS 终止
+DNS/CNAME 指向 +当您为域名启用 CDN 后,通常会在 DNS 中将该域名的 CNAME 记录指向 CDN 运营商提供的专用域名,本地递归 DNS 随后会将解析权交给 CDN 供应商的权威 DNS,实现请求切入 CDN 网络.
+边缘节点出示证书 +用户发起 HTTPS 请求时,浏览器直接与就近的 CDN 边缘节点建立 TLS 连接,边缘节点会出示由受信任 CA(如 Let's Encrypt、DigiCert 等)签发的“边缘证书”,而非您源站的自签名证书.
+源站连接加密 +在边缘节点接收并缓存用户流量后,CDN 再以 HTTPS(或 HTTP,根据配置)向源站发起请求.此时,您可以在源站使用自签名证书(或 Cloudflare Origin CA 自签名证书),仅保证 CDN 与源站之间的加密传输,且该证书对终端用户浏览器不可见.
+以 Cloudflare 为例,常见的四种 SSL/TLS 模式对自签名证书的处理策略如下:
+Flexible:浏览器 ↔ CDN 边缘 使用 HTTPS;CDN 边缘 ↔ 源站 使用 HTTP,不接触证书验证.
+Full:浏览器 ↔ CDN 边缘 使用 HTTPS;CDN 边缘 ↔ 源站 使用 HTTPS,但不验证源站证书的 CA 链和域名匹配,可使用自签名证书. +Cloudflare Docs
+Full (strict):浏览器 ↔ CDN 边缘 使用 HTTPS;CDN 边缘 ↔ 源站 使用 HTTPS,严格验证源站证书是否由受信任 CA 签发且域名匹配,不支持自签名证书. +Cloudflare Docs
+Off:关闭 HTTPS,加密支持完全关闭.
+若您选择 Full 或 Flexible 模式,即使源站使用自签名证书,CDN 也不会在边缘层对其进行验证,仍会正常转发和缓存内容;而用户浏览器只会看到 CDN 边缘提供的受信任证书,因此不会出现“不受信任”警告.
+++为什么浏览器会信任? 浏览器内置了受信任的根证书列表,CDN 边缘出示的证书链会完整地链接到某个系统信任根,而您的自签名证书则不在此列表内,因而只有源站连接可被 CDN 信任,而非终端浏览器.CDN 则作为“可信中间人”,它信任自签名证书以加密与源站的通信,而浏览器仅信任 CDN 边缘的 CA 签发证书,二者互不干扰,有效隔离了自签名的风险.
+
要在 Cloudflare 上启用 Full (Strict) 模式,以确保 CDN 与源站之间的通信既加密又验证证书的有效性,请按照以下步骤操作:
+✅ 步骤 1:确保源站配置了有效的 SSL/TLS 证书
+在启用 Full (Strict) 模式之前,您的源站必须安装一个有效且受信任的 SSL/TLS 证书.您可以选择以下方式之一:
+使用公共 CA 颁发的证书:如 Let's Encrypt、DigiCert、GlobalSign 等.
+
+使用 Cloudflare Origin CA 证书:这是 Cloudflare 提供的免费证书,专为与其边缘节点通信设计.
+
+确保证书未过期,且域名匹配正确.如果使用 Cloudflare Origin CA 证书,请在源站服务器上正确安装,并配置服务器(如 Nginx、Apache)以使用该证书.
+✅ 步骤 2:在 Cloudflare 仪表板中启用 Full (Strict) 模式
+登录到您的 Cloudflare 仪表板.
+
+选择您要配置的站点.
+
+在左侧菜单中,点击 “SSL/TLS”.
+
+在 “概览(Overview)” 标签下,找到 “SSL/TLS 加密模式(SSL/TLS encryption mode)”.
+
+选择 “Full (Strict)” 模式.
+
+更改后,Cloudflare 会立即应用此设置.建议等待几分钟,然后通过浏览器访问您的网站,确保一切正常运行.
+🔗 注意事项
+如果源站使用的是自签名证书或过期的证书,启用 Full (Strict) 模式后,Cloudflare 将无法建立连接,用户可能会看到 526 错误.
+确保源站服务器的时间设置正确,以避免因时间不一致导致的证书验证失败.
+DNSSEC(Domain Name System Security Extensions,域名系统安全扩展)是一组为 DNS 协议设计的安全机制,旨在通过数字签名验证 DNS 数据的真实性和完整性,防止域名解析过程中的数据篡改和伪造.
+DNSSEC 通过引入以下关键机制来增强 DNS 的安全性:
+数字签名(RRSIG 记录):每个 DNS 记录集(如 A、MX、CNAME 等)都会生成一个对应的数字签名,确保记录在传输过程中未被篡改.
+公钥发布(DNSKEY 记录):用于存储验证数字签名所需的公钥.这些公钥本身也通过上级域的签名进行验证,形成信任链.
+委派签名者(DS 记录):上级域使用 DS 记录存储下级域的 DNSKEY 记录的摘要,确保公钥的真实性.
+不存在性证明(NSEC/NSEC3 记录):用于明确指示某个 DNS 记录不存在,防止攻击者伪造不存在的记录.
+通过这些机制,DNSSEC 建立了一条从根域开始的信任链,逐级验证每个域的 DNS 数据,确保其未被篡改且来源可信.
+不加密数据内容:DNSSEC 仅对 DNS 数据进行签名验证,并不加密查询和响应内容,因此无法防止数据被监听.
+部署复杂性:实施 DNSSEC 需要域名注册商、DNS 服务提供商和客户端解析器的共同支持,部署和维护相对复杂.
+性能影响:由于引入了额外的签名验证过程,DNSSEC 可能会增加 DNS 查询的响应时间和系统资源消耗.
+防止 DNS 欺骗和缓存投毒:通过验证 DNS 数据的真实性,DNSSEC 能有效防止攻击者伪造 DNS 响应,将用户引导至恶意网站.
+增强互联网基础设施安全性:作为互联网信任体系的一部分,DNSSEC 为其他安全协议(如 DANE)提供基础支持.
+Netlify在考虑到CDN成本以及可用性的情况下选择了以下这些地区以保证全球大部分访客访问他们的服务都能有不错的连接性和访问速度。
+欧洲中部(德国法兰克福)
+南美(巴西圣保罗)
+美东(美国弗吉尼亚)
+美西(美国旧金山)
+亚洲(新加坡)
+大洋洲(澳大利亚悉尼)
+
+那么Netlify为什么会选择把CDN节点放到这些地区呢?
+1.弗吉尼亚,美东的弗吉尼亚被誉为“全球数据中心之都",美国政府对这个地区的网络投入非常大,使得弗吉尼亚的全球互联(美国本土、欧洲以及到南美洲)优秀。
+2.旧金山,面向亚太和美西的访客。需要注意的是美西对亚太的网络连接比较优秀,但是到南美不太理想,甚至还有丢包的情况。
+3.法兰克福,面向欧洲用户,德国法兰克福或者荷兰阿姆斯特丹都是不错的选择。
+4.新加坡,亚太地区数据中心的枢纽,到印度、日本、越南、香港、中国移动的联通性都不错。
+5.悉尼,土澳出了名的国际互联不太好,悉尼节点主要是服务本地和周边。
+6.圣保罗,南美市场。
+++需要注意的是有些CDN的回源IP并不用作节点IP,比如Cloudflare的回源IP仅作回源IP使用,如果要获取Cloudflare的节点IP,可前往https://bgp.tools/as/13335#prefixes。而有些CDN的回源IP同时被用作CDN节点,比如BunnyCDN和Gcore CDN。
+
Cloudflare
+# https://www.cloudflare.com/ips-v4
+103.21.244.0/22
+103.22.200.0/22
+103.31.4.0/22
+104.16.0.0/13
+104.24.0.0/14
+108.162.192.0/18
+131.0.72.0/22
+141.101.64.0/18
+162.158.0.0/15
+172.64.0.0/13
+173.245.48.0/20
+188.114.96.0/20
+190.93.240.0/20
+197.234.240.0/22
+198.41.128.0/17
+
+# https://www.cloudflare.com/ips-v6
+2400:cb00::/32
+2405:8100::/32
+2405:b500::/32
+2606:4700::/32
+2803:f800::/32
+2a06:98c0::/29
+2c0f:f248::/32
+
+Gcore
+https://api.gcore.com/cdn/public-ip-list
+
+BunnyCDN
+https://api.bunny.net/system/edgeserverlist
+https://api.bunny.net/system/edgeserverlist/plain
+
+Cloudfront
+https://d7uri8nf7uskq.cloudfront.net/tools/list-cloudfront-ips
+https://files.imunify360.com/static/whitelist/v2/cloudfront-cdn.txt
+
+CDN77
+https://files.imunify360.com/static/whitelist/v2/cdn77.txt
+
+Fastly
+https://api.fastly.com/public-ip-list
+
+Keycdn
+https://www.keycdn.com/shield-prefixes.json
+
+quic.cloud
+https://quic.cloud/ips
+
+Google CDN
+https://files.imunify360.com/static/whitelist/v2/google-cdn.txt
+
+CacheFly
+https://cachefly.cachefly.net/ips/cdn.txt
+
+Akaima
+https://techdocs.akamai.com/origin-ip-acl/docs/update-your-origin-server
+
+Done.
+ +前言 Docker的出现极大简化了建站流程,较过去的LAMP方式优雅了许多,配合Nginx反向代理可以快速上线HTTPS站点。
+这里以Debian12为例:
+curl -fsSL https://get.docker.com -o get-docker.sh
+sudo sh get-docker.sh
+
+使用以下命令安装此方法的先决条件:
+sudo apt update && sudo apt install ca-certificates curl gnupg
+
+创建一个目录来存储密钥环:
+sudo install -m 0755 -d /etc/apt/keyrings
+
+使用给定的命令下载 GPG 密钥并将其存储在 /etc/apt/keyrings/etc/apt/keyrings 目录中:
curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
+
+使用 chmod 命令更改 docker.gpg 文件的权限:
+sudo chmod a+r /etc/apt/keyrings/docker.gpg
+
+使用以下命令为 Docker 设置存储库:
+echo \
+ "deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/debian \
+ "$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | \
+ sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
+
+现在可以使用以下命令更新存储库索引并安装 Docker:
+sudo apt update && sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
+
+| 命令 | 说明 |
|---|---|
docker version | 查看 Docker 版本信息 |
docker info | 查看 Docker 系统信息,包括镜像和容器数量 |
docker help | 查看帮助信息 |
docker <command> --help | 查看某个命令的详细帮助 |
| 命令 | 说明 |
|---|---|
docker images | 列出本地所有镜像 |
docker search nginx | 从 Docker Hub 搜索镜像 |
docker pull nginx:latest | 拉取镜像 |
docker rmi nginx:latest | 删除镜像 |
docker rmi $(docker images -q) | 删除所有镜像 |
docker inspect nginx | 查看镜像详细信息 |
docker tag nginx myrepo/nginx:v1 | 给镜像打标签 |
docker save -o nginx.tar nginx | 导出镜像为 tar 包 |
docker load -i nginx.tar | 从 tar 文件加载镜像 |
| 命令 | 说明 |
|---|---|
docker ps | 查看正在运行的容器 |
docker ps -a | 查看所有容器(包括已停止) |
docker run -d -p 80:80 --name web nginx | 启动容器(后台运行) |
docker run -it ubuntu /bin/bash | 启动交互式容器 |
docker exec -it web bash | 进入正在运行的容器 |
docker logs -f web | 查看容器日志(-f 实时输出) |
docker stop web | 停止容器 |
docker start web | 启动容器 |
docker restart web | 重启容器 |
docker rm web | 删除容器 |
docker rm $(docker ps -aq) | 删除所有容器 |
docker inspect web | 查看容器详细信息 |
docker stats | 查看容器资源使用情况 |
docker top web | 查看容器内运行的进程 |
docker cp web:/path/in/container ./localdir | 从容器复制文件到主机 |
docker cp ./file web:/path/in/container | 从主机复制文件到容器 |
| 命令 | 说明 |
|---|---|
docker network ls | 列出所有网络 |
docker network inspect bridge | 查看网络详情 |
docker network create mynet | 创建自定义网络 |
docker network connect mynet web | 将容器连接到网络 |
docker network disconnect mynet web | 将容器从网络断开 |
docker network rm mynet | 删除网络 |
| 命令 | 说明 |
|---|---|
docker volume ls | 查看所有卷 |
docker volume create mydata | 创建数据卷 |
docker volume inspect mydata | 查看卷详情 |
docker volume rm mydata | 删除数据卷 |
docker run -v mydata:/data nginx | 启动容器并挂载卷 |
docker run -v $(pwd):/app nginx | 挂载主机目录到容器中 |
| 命令 | 说明 |
|---|---|
docker build -t myapp:latest . | 构建镜像 |
docker commit web myimage:v1 | 将容器保存为镜像 |
docker save -o myimage.tar myimage:v1 | 导出镜像文件 |
docker load -i myimage.tar | 导入镜像文件 |
docker export web > web.tar | 导出容器文件系统 |
docker import web.tar myweb:v1 | 从 tar 文件导入镜像 |
| 命令 | 说明 |
|---|---|
docker system df | 显示磁盘使用情况 |
docker system prune | 清理无用的容器、镜像、卷和网络 |
docker image prune | 清理未使用的镜像 |
docker container prune | 清理已停止的容器 |
docker volume prune | 清理无用卷 |
| 命令 | 说明 |
|---|---|
docker compose up -d | 启动服务(后台) |
docker compose down | 停止并删除容器 |
docker compose ps | 查看当前项目容器 |
docker compose logs -f | 查看日志 |
docker compose build | 重新构建服务镜像 |
docker compose restart | 重启服务 |
++删除所有 Docker 容器和 Docker 本身
+
docker stop $(docker ps -aq)
+
+删除所有容器(包括停止的容器):
+docker rm $(docker ps -aq)
+
+docker rmi $(docker images -q)
+
+docker network prune -f
+
+docker volume prune -f
+
+如果您希望完全删除 Docker 本身,可以执行以下命令:
+sudo apt-get purge docker-ce docker-ce-cli containerd.io
+sudo apt-get autoremove --purge
+sudo rm -rf /var/lib/docker
+sudo rm -rf /etc/docker
+
+这些命令会卸载 Docker 软件并删除 Docker 数据目录。
+Searxng服务并对外开放。使用同一个外部 Docker 网络使两个服务互联。创建好工作目录,例如:.
+└── docker
+ ├── docker-compose.nginx.yml
+ ├── docker-compose.searxng.yml
+ └── nginx
+ ├── certs
+ │ ├── fullchain.pem
+ │ └── privkey.pem
+ └── searxng.conf
+
+docker network create nginx
+
+这样,无论是哪个 docker-compose 项目中的容器,只要加入此网络,就能直接通信。
+version: '3'
+
+services:
+ searxng:
+ image: searxng/searxng
+ container_name: searxng
+ restart: unless-stopped
+ ulimits:
+ nproc: 65535
+ nofile:
+ soft: 65535
+ hard: 65535
+ volumes:
+ - /var/lib/docker/volumes/searxng/_data:/etc/searxng
+ networks:
+ - nginx
+ ports:
+ # 如果希望 searxng 只对内部服务开放,则可不映射外部端口
+ - "127.0.0.1:18080:8080"
+
+networks:
+ nginx:
+ external: true
+
+创建 nginx 的 docker-compose 文件,例如:
+version: '3'
+
+services:
+ nginx:
+ image: nginx:latest
+ container_name: nginx
+ restart: unless-stopped
+ ports:
+ - "80:80"
+ # 如需要 HTTPS,请映射 443 端口并挂载证书目录
+ #- "443:443"
+ volumes:
+ - ./nginx/searxng.conf:/etc/nginx/conf.d/default.conf:ro
+ #- ./nginx/certs:/etc/nginx/certs:ro
+ networks:
+ - nginx
+
+networks:
+ nginx:
+ external: true
+
+server {
+ listen 80;
+ server_name searxng.dich.bid;
+
+ client_max_body_size 10M;
+
+ location / {
+ proxy_pass http://searxng:8080;
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_set_header X-Forwarded-Proto $scheme;
+ proxy_http_version 1.1;
+ proxy_set_header Connection "";
+ }
+
+ error_page 502 /502.html;
+ location = /502.html {
+ root /usr/share/nginx/html;
+ internal;
+ }
+}
+
+docker-compose -f docker-compose.searxng.yml up -d
+
+docker-compose -f docker-compose.nginx.yml up -d
+
+由于两者都加入了外部网络 nginx,nginx 内的proxy_pass http://searxng:8080就能解析到 searxng 容器,实现反向代理效果。现在,访问http://ip:18080就可以访问Searxng搜索引擎。
在实际生产环境中我们不能使用IP直接访问,因此需要为我们的站点开启SSL证书,也就是要申请证书并在配置文件中声明。
+mkdir -p /home/dich/docker/nginx/certs
+openssl req -x509 -nodes -days 365 -newkey rsa:2048 \
+ -keyout /home/dich/docker/nginx/certs/privkey.pem \
+ -out /home/dich/docker/nginx/certs/fullchain.pem \
+ -subj "/CN=your-domain.com"
+
+server {
+ listen 443 ssl;
+ server_name searxng.dich.bid;
+
+ # SSL 证书配置
+ ssl_certificate /home/dich/docker/nginx/certs/fullchain.pem;
+ ssl_certificate_key /home/dich/docker/nginx/certs/privkey.pem;
+ ssl_protocols TLSv1.2 TLSv1.3;
+ ssl_ciphers HIGH:!aNULL:!MD5;
+
+ client_max_body_size 10M;
+
+ location / {
+ proxy_pass http://searxng:8080;
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_set_header X-Forwarded-Proto $scheme;
+ proxy_http_version 1.1;
+ proxy_set_header Connection "";
+ }
+
+ error_page 502 /502.html;
+ location = /502.html {
+ root /usr/share/nginx/html;
+ internal;
+ }
+}
+
+# HTTP 服务器块,将所有流量重定向到 HTTPS
+server {
+ listen 80;
+ server_name searxng.dich.bid;
+ return 301 https://$host$request_uri;
+}
+
+version: '3'
+
+services:
+ nginx:
+ image: nginx:latest
+ container_name: nginx
+ restart: unless-stopped
+ ports:
+ - "80:80"
+ # 如需要 HTTPS,请映射 443 端口并挂载证书目录
+ - "443:443"
+ volumes:
+ - ./nginx/searxng.conf:/etc/nginx/conf.d/default.conf:ro
+ - ./nginx/certs:/home/dich/docker/nginx/certs
+ networks:
+ - nginx
+
+networks:
+ nginx:
+ external: true
+
+sudo docker compose -f docker-compose.nginx.yml up -d
+
+sudo docker logs searxng
+
+++Caddy 自 2015 年起用 Go 语言重写,定位为“开箱即用”的现代 Web 服务器,内置自动 Let’s Encrypt 证书管理和续期,默认支持 HTTP/2 及 HTTP/3(QUIC),并通过简洁明了的 Caddyfile 语法极大降低配置成本.
+
.
+└── compose
+ ├── certs
+ │ ├── cert.pem
+ │ └── key.pem
+ ├── compose.caddy.yml
+ ├── compose.miniflux.yml
+ ├── compose.searxng.yml
+ └── conf
+ └── Caddyfile
+
+docker network create caddy
+
+version: '3.7'
+
+# 自动签发模式
+
+services:
+ caddy:
+ image: caddy:latest
+ container_name: caddy
+ restart: unless-stopped
+ volumes:
+ - ./conf:/etc/caddy:ro
+ - caddy_data:/data
+ - caddy_config:/config
+ ports:
+ - "80:80"
+ - "443:443"
+ networks:
+ - caddy
+
+networks:
+ caddy:
+ external: true
+
+volumes:
+ caddy_data:
+ caddy_config:
+
+
+# 自备证书模式
+
+services:
+ caddy:
+ image: caddy:latest
+ container_name: caddy
+ restart: unless-stopped
+ environment:
+ - CADDYPATH=/etc/caddycerts
+ volumes:
+ - ./conf:/etc/caddy
+ - ./certs:/etc/caddycerts
+ - caddy_data:/data
+ - caddy_config:/config
+ ports:
+ - "80:80"
+ - "443:443"
+ networks:
+ - caddy
+
+volumes:
+ caddy_data:
+ caddy_config:
+networks:
+ caddy:
+ external: true
+
+# 自动签发模式
+searxng.dich.bid {
+ reverse_proxy searxng:8080 {
+ header_up Host {upstream_hostport}
+ }
+}
+
+miniflux.dich.bid {
+ reverse_proxy miniflux:8080 {
+ header_up Host {upstream_hostport}
+ }
+}
+
+# 自备证书模式
+searxng.dich.bid {
+ reverse_proxy searxng:8080
+ tls /etc/caddycerts/cert.pem /etc/caddycerts/key.pem
+}
+miniflux.dich.bid {
+ reverse_proxy miniflux:8080
+ tls /etc/caddycerts/cert.pem /etc/caddycerts/key.pem
+}
+
+FAQ
+Done.
+ +前言 下载,就是将我们所需要的文件数据,通过网络从拥有该文件资源的计算机上传输过来并保存到我们的计算机上,供我们使用。本系列将详细讲述各种常见网络下载技术的原理,包括HTTP,FTP,BT等等。
+ +下载技术的历史可以追溯到计算机网络的早期发展阶段。以下是下载技术的一些历史里程碑:
+早期网络时代(1960s - 1980s): +在计算机网络的早期阶段,下载技术并不像今天这样普及。主要的网络是由军方和学术机构使用的封闭网络,例如阿帕网(ARPANET)。在这个时期,文件通常通过物理介质(如磁带、磁盘或纸带)传输,而不是通过网络进行下载。
+BBS时代(1980s - 1990s): +随着电子通信的发展,出现了电子公告板系统(BBS)。BBS是一种允许用户通过拨号访问的系统,用户可以在BBS上发布和下载文件。下载文件的过程通常是通过模拟调制解调器将文件从BBS服务器下载到个人计算机上。
+Internet时代的起步(1990s): +1990年代初,随着互联网的普及,出现了许多文件下载协议和工具。其中最知名的是FTP(文件传输协议),它允许用户通过网络下载文件到自己的计算机上。FTP是早期互联网上常用的文件传输方式之一,但它需要用户在计算机上安装专用的FTP客户端软件。
+万维网时代的兴起(1990s): +随着万维网(World Wide Web)的诞生,HTTP(超文本传输协议)成为了互联网上最流行的协议之一。HTTP允许用户通过标准的Web浏览器直接从Web服务器上下载文件。这一时期也出现了许多下载管理器和加速器,例如IDM(Internet Download Manager),用于提高文件下载的速度和管理。
+P2P文件共享时代(2000s至今): +P2P(点对点)文件共享技术允许用户直接从其他用户的计算机上下载文件,而不是从中央服务器下载。著名的P2P协议包括BitTorrent和eDonkey等。这些技术使得文件下载更加分布式,并且提供了更高的下载速度和可靠性。
+流媒体下载和订阅服务(2000s至今): +随着互联网带宽的增加,视频和音频流媒体下载成为主流。诸如Netflix、Spotify和Apple Music等订阅服务提供了通过互联网访问大量内容的途径,用户可以通过流媒体服务下载并观看/收听内容,而无需等待完全下载。
+HTTP,全名 HyperText Transfer Protocol,超文本传输协议。
+HTTP协议是一种无状态的、应用层协议,用于传输超文本数据,如HTML、图片、音视频等。
HTTP下载的基本原理:
+浏览器请求:用户在浏览器中点击下载链接或按钮时,浏览器会向服务器发送HTTP请求,请求下载指定的文件。
+服务器响应:服务器收到下载请求后,会根据请求中的信息找到对应的文件,并将文件内容打包成HTTP响应发送给客户端。
+传输过程:一旦浏览器接收到服务器的响应,就开始从服务器下载文件。这个过程可以简单地分为以下几个步骤:
+下载完成:一旦文件的所有数据都被下载到本地,浏览器就会将临时文件转移到用户指定的下载文件夹中,完成文件的下载过程。
+在整个HTTP下载过程中,浏览器会根据服务器返回的HTTP响应头中的一些信息来确定如何处理下载文件,例如文件类型、大小、以及是否支持断点续传等。此外,如果用户使用的是下载管理器或浏览器插件,这些工具还可以提供更多的下载管理功能,如多线程下载、下载加速、断点续传等。
+当我们点击一个链接时,浏览器会检查链接指向的目标是什么类型。如果是浏览器支持的类型,比如一个 HTML 文件,也就是另一个网页,则会跳转到新页面。
+如果是不能直接由浏览器打开的文件类型,比如一个 EXE 格式的软件包,这时就会调用浏览器的下载机制,开始下载。如果装有下载工具的浏览器插件,浏览器则会将下载任务转交给下载工具进行,等待一段时间,下载完成之后,这个文件就会出现在我们的下载文件夹中。这就是最基本的下载,HTTP 下载。
+上世纪 90 年代,中国互联网的发展初期,在当时计算机上网只能通过电话线路,经由调制解调器来进行,因此称作拨号上网。
+拨号上网的基本原理:
+调制解调器(Modem):在拨号上网时,计算机通过调制解调器将数字数据转换成模拟信号发送到电话线路上,以及接收从电话线路传来的模拟信号并将其转换成数字数据。调制解调器是连接计算机和电话线路的关键设备。
+拨号过程:用户在计算机上设置拨号连接,输入拨号号码(通常是ISP提供的拨号号码),计算机通过调制解调器拨号建立连接。拨号过程中,调制解调器会发送一系列信号给拨号接入点,以建立与网络服务提供商(ISP)的连接。
+网络连接:一旦拨号成功,计算机与ISP的服务器建立起网络连接。在拨号过程中,计算机会获取到一个IP地址,这个IP地址是计算机在网络上的唯一标识符,用于进行数据传输。
+数据传输:一旦网络连接建立,计算机就可以通过调制解调器在电话线路上发送和接收数据。数据传输可以是双向的,用户可以浏览网页、发送电子邮件、下载文件等。
+电话和上网的冲突:在拨号上网的过程中,电话线路和上网信号不能同时传输,如果在上网过程中接听电话,网络连接会中断。这是因为电话和上网信号共用同一条电话线路,无法同时传输。
+断线重连:如果网络连接因为电话中断或其他原因而中断,用户需要重新拨号连接到ISP的服务器,继续上网。这种中断和重连过程是拨号上网时常见的情况。
+拨号上网的速度较慢,且容易受到电话和上网信号冲突的影响,因此在宽带互联网普及后逐渐被淘汰。
+当时的网费不是按年收取的,而是与打电话一样按时计费,费用大约为每小时 20 元,而且这还是房地产未爆发之时的 20 元。
+当时最高网速为 56 kbps,也就是 7 KB/s,一首 MP3 音乐大约为 4 M,需要下载 10 分钟。但如果是一个红警 2 的游戏,约 200 M,那就需要下载 8 小时。8 小时的网费 160 元,而一张盗版光盘只需要 5 元。因此,虽然光盘现如今已经被沉入了历史长河,但它依然留存在老一代游戏玩家心中,是他们无法抹去的一份美好记忆。
+下载时间长、网费贵,最要命的是电话信号和上网信号不能并行传输,接听来电会中断网络传输,然后你就必须重新下载。
+拨号上网的电话和网络不能同时进行的致命问题,在几年后随着 ADSL 宽带技术的出现,得以解决。但这并不是说,下载就不再会被中断了。电话是不怕了,但死机、停电、软件崩溃、服务器当机等等,还有无数种暂停下载的情况。
+断点续传的基本原理:
+HTTP Range和Content-Range头字段:为了支持断点续传,HTTP 1.1标准在1999年引入了Range和Content-Range头字段。这些字段允许客户端指定要请求的文件的特定范围,并且允许服务器指定响应的内容的范围。
+客户端支持:下载工具需要能够识别并利用HTTP Range头字段。当下载中断时,下载工具会将已经下载的部分保存到本地硬盘上,同时记录下已下载的字节数和文件的URL等信息。
+中断处理:如果下载过程中出现网络中断或其他原因导致下载中断,下载工具会保存当前已下载的部分,并在下次恢复下载时利用HTTP Range头字段向服务器发出请求,请求从中断处继续下载。
+服务端支持:服务器需要能够处理带有Range头字段的请求,并能够正确响应所请求的文件的特定范围。服务器根据客户端请求的字节范围返回相应部分的文件内容,并且在响应头中包含Content-Range字段指示所返回的文件部分的范围和总大小。
+续传合并:一旦下载工具完成对剩余部分的下载,它会将先前保存的部分和新下载的部分合并成完整的文件。这通常涉及到文件操作,如将两个文件的内容按顺序拼接到一起。
+然而,要实现断点续传,客户端和服务器双方都必须支持相关的HTTP头字段和逻辑,否则无法进行断点续传。
+互联网早期,上网用户少,但内容提供商更少。因此提供下载的网站一般都是满带宽运行的。而且在晚上的高峰期,能分给每个用户的带宽就更少了。因此大多数用户的下载速度都很低,远低于自己的网络带宽,这对于按时计费的上网环境来说,就是一种极大的浪费。因此人们又希望能有一种可以提升下载速度的方法。
+多线程下载Multi-threaded Download是一种通过同时启动多个下载线程来加快文件下载速度的技术。以下是多线程下载的基本原理:
并行下载:在开始下载任务时,下载工具会同时启动多个下载线程,每个线程负责下载文件的不同部分。例如,如果设定了5个下载线程,那么下载工具会将文件分成5个部分,每个线程负责下载其中的一部分。
+断点续传:每个下载线程都利用断点续传技术,向服务器发出请求,并在HTTP请求中指定自己要下载的文件的起止位置。服务器根据这些请求返回相应的文件部分,而不是整个文件。
+并行下载过程:各个下载线程同时下载文件的不同部分,因此可以充分利用网络带宽资源,加快文件的下载速度。由于每个线程独立工作,所以它们之间互不影响,即使某个线程下载中断,其他线程仍然可以继续下载。
+文件合并:当所有下载线程都完成了各自部分的下载后,下载工具将这些部分按顺序合并成完整的文件。这通常是在本地文件系统中进行的简单文件操作,将各个部分的内容按顺序写入到一个文件中。
+提升下载速度:多线程下载技术可以有效地提升文件的下载速度,尤其是对于大文件或者带宽较小的网络连接。通过利用多个下载线程同时下载文件的不同部分,可以充分利用网络带宽资源,加快文件的下载速度。
+多线程下载技术的出现极大地改善了用户在互联网上下载文件的体验,使得用户可以更快地获取所需的文件内容。许多下载工具如网络蚂蚁、FlashGet、IDM等都采用了多线程下载技术,为用户提供了更高效的下载服务。
+FTPFile Transfer Protocol即文件传输协议是一种用于在计算机之间传输文件的标准网络协议。它提供了一种简单而有效的方式,允许用户从一个主机(FTP服务器)下载文件到另一个主机(客户端)或上传文件到服务器。
以下是FTP协议及其下载原理的详细说明:
+工作模式:FTP使用客户端-服务器模式,客户端向服务器发出命令并接收服务器的响应来进行文件传输。
+端口:FTP使用TCP协议,服务器默认监听端口为21,用于控制连接,数据传输则使用动态端口(通常是20)。
+认证:用户需要通过用户名和密码进行身份验证才能连接到FTP服务器。
+命令和响应:FTP客户端通过发送命令到服务器来执行各种操作,例如列出目录、下载文件、上传文件等。服务器接收到命令后,执行相应的操作,并向客户端发送响应。
+FTP下载的基本原理涉及以下几个步骤:
+建立连接:客户端向服务器发送连接请求,服务器响应并建立控制连接。控制连接用于发送FTP命令和接收服务器响应。
+身份验证:客户端发送用户名和密码进行身份验证。一旦验证通过,客户端可以开始执行FTP命令。
+浏览文件:客户端可以使用FTP命令浏览服务器上的文件和目录结构,例如LIST命令用于列出目录内容。
选择文件:客户端通过FTP命令选择要下载的文件,例如RETR命令用于从服务器下载文件。
建立数据连接:在下载文件之前,客户端需要与服务器建立数据连接。数据连接用于实际传输文件内容。
+下载文件:一旦数据连接建立,服务器开始向客户端发送文件内容。客户端接收文件数据,并将其保存到本地文件系统中。
+关闭连接:文件传输完成后,客户端关闭数据连接,并向服务器发送命令关闭控制连接。
+FTP连接可以使用主动模式(Active Mode)或被动模式(Passive Mode)进行数据传输。
+主动模式:在主动模式下,客户端向服务器的数据端口(通常是端口20)发送连接请求,服务器通过控制端口(端口21)响应,并在数据端口上发送数据。
+被动模式:在被动模式下,客户端发送连接请求到服务器的控制端口(端口21),服务器响应并在一个随机的高端口打开一个监听,并将这个端口号发送给客户端。然后客户端连接到服务器的高端口上进行数据传输。
+被动模式通常用于避免防火墙问题和NAT设备的限制,因为它允许数据连接从服务器向客户端发起,而不是从客户端向服务器发起。
+FTP协议最初设计时并没有考虑到安全性,因此在传输过程中文件内容以明文形式传输,存在安全风险。为了解决这个问题,可以通过使用FTP over SSL(FTPS)或FTP over SSH(SFTP)等安全扩展来加密传输数据。
+BT 全称 BitTorrent,一般不翻译,非要翻译的话,那就是“比特洪流”。它一般指基于 P2P 下载机制而设计的一个具体协议。BT 三大客户端µTorrent、qBittorrent 和 Transmission,µ是希腊字母,不好输入,所以也常写作 uTorrent。
BT下载技术的基本原理:
+种子文件创建:一个用户想要共享一个文件时,他会创建一个种子文件。种子是一个很小的,大约几十 kB 的,后缀名为 .torrent 的文件。种子内存储有该资源所包含文件的文件名、哈希值和 Tracker,哈希值是一个长度几十位不等的16进制数字,用于判断一个文件是否因传输过程而损坏或被恶意篡改。其原理可以简单理解为将一个超大数字的每位相加,再求余,这样以来,文件中哪怕有一个字节的变动或增减,都会导致对应哈希值的变化。BT 客户端在文件下载完成后会重新计算其哈希值,并与种子内保存的哈希值进行比较。如果不同,则表示下载过程中出现数据损坏,需要重新下载。BT 协议还会对体积较大的文件进行切片处理,从而减小重新下载所需的数据量。
+分块:文件会被分成一个个固定大小的块(通常为256KB或512KB),每个块都有一个唯一的标识符。
+连接Tracker服务器:用户启动BT客户端后,首先需要连接Tracker服务器来获取其他参与文件共享的用户信息。Tracker 是一个服务器地址,与 HTTP 下载服务器不同的是,它不保存文件内容,只保存文件的哈希值,和已下载过该文件的所有用户的 IP 地址。也就是说,当你获得一个种子文件,并添加到 BT 客户端之后,BT 客户端所做的第一步就是,向种子内保存的 Tracker 服务器询问“哪些人已经下载了这个文件?”Tracker 服务器就会将对应的 IP 地址列表,返回给你的 BT 客户端Tracker服务器会返回一份参与文件共享的用户列表,称为peer list。
+连接Peers:P2P 英文全称 Peer To Peer。一般不翻译,非要翻译的话,那就是“点对点”或“对等”,即这种新型下载方式的运作机制。 +根据Tracker服务器返回的peer list,用户的BT客户端会尝试连接其中的其他用户(也称为peer)。通过这些连接,用户可以请求和发送文件块。
+下载块:一旦连接到其他用户,用户的客户端就会开始请求文件的不同块。客户端会根据需要的块选择合适的peer,并向其发送请求。其他peer收到请求后,会响应并将相应的块发送给请求者。
+上传块:用户的BT客户端不仅仅是下载文件,也在上传文件。当用户下载了一个块后,它也会成为一个可供其他用户下载的资源,用户的客户端会将这个块发送给其他请求者。
+分块验证:一旦下载完成,客户端会验证每个块的完整性。如果发现某个块不完整或者损坏,客户端会请求相同的块,直到下载到一个完整的块。
+做种:当一个用户完全下载了文件并且保持BT客户端运行时,他就成为了一个seeder(种子),即可供其他用户下载文件的资源。种子会周期性地向Tracker服务器发送自己的信息,以便其他用户找到他并下载文件。
+++迅雷也会从别的 BT 软件那里下载资源,但它拒绝向其共享,它只共享给其他同样使用迅雷的用户。这严重违背 P2P 共享的公平原则,因此迅雷被称为吸血雷。
+
++专用下载链接
+
PTPrivate Tracker是一种私有的BitTorrent Tracker系统,与公开的BitTorrent网络不同,它需要用户进行注册和认证才能访问和下载文件。下面是PT下载技术的基本原理:
注册和认证:用户需要注册一个账户,并且经过认证才能够访问PT站点。认证通常包括通过邀请码注册或者通过一定的上传/下载比例限制。
+获取种子文件:与公开的BitTorrent网络不同,PT站点上的种子文件通常需要用户登录后才能够访问和下载。种子文件包含了文件的元数据信息以及Tracker服务器的地址。
+连接Tracker服务器:用户启动BT客户端后,首先需要连接PT站点的Tracker服务器来获取其他参与文件共享的用户信息。Tracker服务器会返回一份peer list。
+连接Peers:与公开的BitTorrent网络类似,用户的BT客户端会根据Tracker服务器返回的peer list,尝试连接其他参与文件共享的用户(peer)。
+下载块:一旦连接到其他用户,用户的客户端就会开始请求文件的不同块。客户端会根据需要的块选择合适的peer,并向其发送请求。其他peer收到请求后,会响应并将相应的块发送给请求者。
+上传块:与公开的BitTorrent网络类似,用户的BT客户端在下载文件的同时也会上传文件。下载的块也会被上传给其他用户。
+分块验证:下载完成后,客户端会验证每个块的完整性。如果发现某个块不完整或者损坏,客户端会请求相同的块,直到下载到一个完整的块。
+保种:保种是PT站点非常重要的概念。用户需要保持下载的文件在客户端中并继续上传给其他用户,以维持站点的健康和分享比例。保种也是PT站点会设置上传/下载比例限制的原因之一。
+PT 与 BT 的一个较大的区别是,PT 会时刻计算每个用户的上传量和下载量,由此来得到每个用户的一个指标“分享率”,分享率过低会被取消使用资格。
+因此与 BT 用户的想法“我要多多下载,然后下完就跑” 相比,PT 用户的想法则是“你们赶紧下载我的资源吧,我还有一季美剧要追呢”。最终结果就是,大多数 BT 种子都下载不动,而 PT 种子则都可以高速下载。
+ed2k 全称 eDonkey2000 即“电驴”,同时也是其协议 ed2k:// 的名称,一般不翻译,非要翻译的话,那就是“电驴链接”。其与 BT 1.0 是同一时期出现,且为技术原理相同的软件。ed2k 与 BT 相比,它不需要种子文件所有必要信息,比如文件名、哈希值、Tracker 地址等信息都编码并保存在这个地址中。唯一的缺点是不能像种子一样保存多个文件,比如用一个种子文件保存整部电视剧的全部剧集或者更夸张的,一个种子保存一万部电影。
+2002 年,一个 eDonkey2000 的程序员用户 ,对当时的 eDonkey2000 客户端不满意,并且相信自己能做出更好的 P2P 软件。因此着手开发,并于同年推出了首个版本,他们的软件名为 eMule,中文名“电骡”。电骡兼容电驴的 ed2k 网络,并在电驴的基础上增加了许多其他功能。电骡也基于 Kademlia 协议算法,开发了自己的的去中心化网络 “Kad 网络”。但最最重要的一点是,它是开源的,这一点为 ed2k 在国内的普及奠定了基础。
+2003 年,国内的两个 P2P 下载爱好者,建立了一个 ed2k 资源分享网站 VeryCD。这个网站一直被认为是国内资源最丰富的网站,各种影视、音乐、游戏、软件等资源应有尽有。
+2005 年,也就是 BT 2.0 元年,在美国唱片协会的状告之下,eDonkey2000关闭了网站,并停止了软件更新。在关闭前夕,其原作者根据 Kademlia 协议算法,开发出了电驴的去中心化 P2P 分享网络 “Overnet”,并更新到了 eDonkey2000 客户端的最后一个版本中。这样使得它的软件在网站关闭之后依然可以使用。
+2007 年,在开源的 eMule 基础上,easyMule诞生了 。对于中文名,他们没有新起,而是尝试强行将自己称作“电驴”。可能是他们觉得电驴已经死了,由他们来继承,或者认为自己是电驴的一个支脉吧。正是这一点,让国内用户对四个英文名 eDonkey、eMule、easyMule、VeryCD 和中文名电驴之间傻傻分不清楚。
+2012 年VeryCD被迫下架了其全部资源的 ed2k 下载链接,此后 VeryCD 也逐渐淡出了人们的视野。
+磁力链是协议名为 magnet: 的下载链接。magnet 是“磁铁”的意思,它在原理和用法上与电驴链接 ed2k:// 几乎是一样的。它允许用户通过简单的URL链接来获取到资源的相关信息,而无需下载一个独立的种子文件。
+基于Hash值的标识:磁力链接是通过资源内容的哈希值来唯一标识的。这个哈希值通常是使用SHA-1算法计算的,并且对应着特定资源的唯一标识符。
+包含元数据信息:磁力链接中还包含了一些资源的元数据信息,如文件名、文件大小、文件分块信息等。这些信息通常是经过URL编码的,并以一种特定的格式嵌入到磁力链接中。
+无需中心化Tracker:与传统的Torrent文件不同,磁力链接中并不包含Tracker服务器的地址。这意味着用户可以直接通过磁力链接获取到资源相关的peer列表,无需依赖中心化的Tracker服务器。
+使用DHT网络:当用户使用磁力链接时,他们的BitTorrent客户端会通过DHT(分布式哈希表)网络来获取资源的相关信息。DHT网络是一个去中心化的网络,允许BitTorrent客户端在没有Tracker服务器的情况下发现其他拥有相同资源的peer。
+动态获取信息:使用磁力链接下载资源时,用户的BitTorrent客户端会动态地从其他拥有相同资源的peer处获取到资源的元数据信息,如文件列表、文件大小等。这样,用户可以立即开始下载资源,而无需等待种子文件下载完成。
+随着电驴和 VeryCD 的关闭,以后互联网上的各种资源的下载,会逐渐从 ed2k 全部转向 magnet。磁力链还可以与 BT 搭配使用,也就是为多个文件制作好 BT 种子之后,再为种子文件制作一个磁力链接,这样就可以既享受 BT 种子支持多个文件的优点,又可以享受 ed2k 和磁力链只需要链接,不需要文件的优点。
+BT 的文件虽然是分布式存储的,但它们的联络员 Tracker 依然是中心化的,只需要借助法律手段,端掉一个 Tracker 服务器,即可让所有 BT 下载瘫痪。因此为了实现完全的防封禁,必须实现完全的去中心化。
+2002 年,美国纽约大学的两位学者,发表了他们的研究成果 Kademlia 协议,并且由 BT 发明者 BitTorrent 客户端,率先于 2005 年支持这种基于 Kademlia 协议的,不依赖Tracker 服务器的 BT 技术。随后,其他 BT 客户端也陆续跟进支持,这标志着 BT 进入 BT 2.0 的时代。
+BT 2.0下载原理:
+分布式Hash表:BT 2.0可能会引入分布式Hash表来替代传统的Tracker服务器。DHT 分布式哈希表网络,英文全称 Distributed Hash Table。其原理就是将原来由 Tracker 服务器保存的“文件哈希 - 文件存储位置” 的映射信息分散存储在 DHT 网络的各个节点中,并且留有冗余,即多份,以保证单个节点在关机之后,也不会影响文件的查询。分布式Hash表可以使peer更容易地发现彼此,减少了对中心化Tracker服务器的依赖。当用户想要下载文件时,他们可以通过Hash值查询分布式Hash表,获取与文件相关的peer列表。
+加密和安全性:BT 2.0引入更强大的加密技术来保护数据传输的安全性和用户的隐私。包括对传输数据进行端到端的加密,以及对用户身份进行更严格的验证和认证。
+内容验证和真实性:BT 2.0引入更多的内容验证机制,以确保下载的文件的真实性和完整性。包括数字签名、哈希验证和数据完整性检查等技术,以防止文件被篡改或损坏。
+带宽管理和QoS优化:BT 2.0改进带宽管理算法,以优化数据传输的效率和性能。包括更智能的下载调度、流量控制和质量of服务(QoS)机制,以确保下载过程中的良好用户体验。
+去中心化和匿名性:BT 2.0加强去中心化和匿名性方面的功能,以保护用户的隐私和匿名性。包括使用Tor网络、区块链技术和匿名代理等,以确保用户的下载行为不被追踪或监视。
+网盘,即位于网络上的硬盘。云的概念兴起以后也被一些厂商称为“云盘”.
+网盘的概念最早起源于电子邮箱的附件存储.相比本地磁盘有诸多优点,它可以防止重要资料因电脑故障而丢失,可以防止机密数据因电脑丢失而外泄。代替 U 盘和移动硬盘在家里和公司之间共享文件。如果你的网盘是同步盘的话,还免去了频繁的手动上传和下载.
+虽然网盘的几T空间看起来很唬人,但对所有用户来说,填充这几 TB 空间的往往是视频资源,而且绝大多数用户均是视频的消费者,也就是从网上下载视频,而不是自己拍摄视频。因此这些视频资源都是高度重叠的。现实情况就是 1000 个用户使用的 1TB 空间,不是占用了 1000TB 的服务器空间,而是 10TB。
+离线下载准确来说,离线下载其实就是其他人替你挂机下载,下载完成后,再传给你。
+添加下载任务:用户通过离线下载服务提供的网页或应用程序界面,将需要下载的文件链接或种子链接添加到下载任务列表中。
+解析链接:离线下载服务会对添加的下载链接进行解析,提取出其中的文件信息和下载地址。
+远程下载:离线下载服务会以其自身的网络连接,从文件来源服务器下载文件。这个过程完全在服务端进行,用户的设备不直接参与下载过程。
+存储文件:下载完成后,文件会被保存在离线下载服务的服务器上,而不是用户的本地设备上。用户可以在需要时通过网页或应用程序界面访问和管理这些文件。
+提供下载链接:一旦文件下载完成,离线下载服务会生成一个新的下载链接或提供直接的文件下载链接给用户。用户可以使用这个链接来下载文件到自己的设备上。
+刚开始使用离线下载的用户,可能会惊叹于离线下载的“秒完成”。这是因为已经有人先于你离线下载过这个资源了,这就是“资源重叠率”。
+Done.
+ +前言 FRP (Fast Reverse Proxy) 是一个用Go语言开发的高性能反向代理应用,可以帮助您轻松地进行内网穿透,对外提供服务.
+FRP (Fast Reverse Proxy) 主要功能包括:
+FRP分为客户端(frpc)和服务端(frps)两部分:
+服务端需要部署在具有公网IP的服务器上。
+wget https://github.com/fatedier/frp/releases/download/v0.51.3/frp_0.51.3_linux_amd64.tar.gz
+
+tar -xzvf frp_0.51.3_linux_amd64.tar.gz
+cd frp_0.51.3_linux_amd64
+
+客户端需要安装在您的内网设备上,例如需要提供服务的电脑、服务器或IoT设备上。
+与服务端安装步骤相同,只需使用frpc程序和frpc.ini配置文件。
+同样下载Windows版本,解压后使用frpc.exe和frpc.ini。
+服务端配置文件为frps.ini,基本配置如下:
+[common]
+# 服务端监听端口,用于与客户端建立连接
+bind_port = 7000
+
+# 用于身份验证的token
+token = yourSecureToken
+
+# 后台管理页面端口(可选)
+dashboard_port = 7500
+dashboard_user = admin
+dashboard_pwd = admin
+
+# 日志配置
+log_file = /var/log/frps.log
+log_level = info
+log_max_days = 3
+
+客户端配置文件为frpc.ini,基本配置如下:
+[common]
+# 服务端的IP地址或域名
+server_addr = x.x.x.x
+# 服务端的端口
+server_port = 7000
+# 认证token,需要与服务端匹配
+token = yourSecureToken
+
+# 示例:SSH服务代理
+[ssh]
+type = tcp
+local_ip = 127.0.0.1
+local_port = 22
+remote_port = 6000
+
+# 示例:HTTP服务代理
+[web]
+type = http
+local_ip = 127.0.0.1
+local_port = 80
+custom_domains = www.yourdomain.com
+
+# frpc.ini
+[common]
+server_addr = x.x.x.x
+server_port = 7000
+token = yourSecureToken
+
+[ssh]
+type = tcp
+local_ip = 127.0.0.1
+local_port = 22
+remote_port = 6000
+
+使用方法:ssh -p 6000 username@服务端IP
# frpc.ini
+[common]
+server_addr = x.x.x.x
+server_port = 7000
+token = yourSecureToken
+
+[web]
+type = http
+local_ip = 127.0.0.1
+local_port = 80
+custom_domains = www.yourdomain.com
+
+在服务端需要将域名解析到服务端IP。
+# frpc.ini
+[common]
+server_addr = x.x.x.x
+server_port = 7000
+token = yourSecureToken
+
+[web-https]
+type = https
+local_ip = 127.0.0.1
+local_port = 443
+custom_domains = www.yourdomain.com
+
+# frpc.ini
+[common]
+server_addr = x.x.x.x
+server_port = 7000
+token = yourSecureToken
+
+[rdp]
+type = tcp
+local_ip = 127.0.0.1
+local_port = 3389
+remote_port = 7001
+
+./frps -c frps.ini
+
+后台运行:
+nohup ./frps -c frps.ini &
+
+双击frps.exe或在命令行运行:
+frps.exe -c frps.ini
+
+./frpc -c frpc.ini
+
+后台运行:
+nohup ./frpc -c frpc.ini &
+
+双击frpc.exe或在命令行运行:
+frpc.exe -c frpc.ini
+
+/etc/systemd/system/frps.service (服务端) 或 /etc/systemd/system/frpc.service (客户端)服务端示例 (frps.service):
+[Unit]
+Description=Frp Server Service
+After=network.target
+
+[Service]
+Type=simple
+ExecStart=/usr/bin/frps -c /etc/frps/frps.ini
+Restart=always
+RestartSec=5s
+
+[Install]
+WantedBy=multi-user.target
+
+客户端示例 (frpc.service):
+[Unit]
+Description=Frp Client Service
+After=network.target
+
+[Service]
+Type=simple
+ExecStart=/usr/bin/frpc -c /etc/frpc/frpc.ini
+Restart=always
+RestartSec=5s
+
+[Install]
+WantedBy=multi-user.target
+
+# 服务端
+sudo systemctl enable frps
+sudo systemctl start frps
+
+# 客户端
+sudo systemctl enable frpc
+sudo systemctl start frpc
+
+sudo systemctl status frps
+# 或
+sudo systemctl status frpc
+
+nssm.exe install frpc C:\path\to\frpc.exe -c C:\path\to\frpc.ini
+
+nssm.exe start frpc
+
+要支持HTTPS服务,需要在服务端添加配置:
+# frps.ini
+[common]
+bind_port = 7000
+vhost_https_port = 443
+
+客户端配置:
+# frpc.ini
+[web]
+type = https
+local_ip = 127.0.0.1
+local_port = 443
+custom_domains = www.yourdomain.com
+
+使用多路复用可以减少连接数,提高性能:
+# frpc.ini
+[common]
+server_addr = x.x.x.x
+server_port = 7000
+token = yourSecureToken
+# 启用多路复用
+tls_enable = true
+pool_count = 5
+
+增加数据传输的安全性:
+# frpc.ini
+[common]
+server_addr = x.x.x.x
+server_port = 7000
+token = yourSecureToken
+# 启用加密和压缩
+use_encryption = true
+use_compression = true
+
+通过配置多个后端服务实现负载均衡:
+# frpc.ini
+[web]
+type = tcp
+local_ip = 127.0.0.1
+local_port = 80
+remote_port = 8080
+group = web
+group_key = 123456
+
+[web2]
+type = tcp
+local_ip = 127.0.0.1
+local_port = 8081
+remote_port = 8080
+group = web
+group_key = 123456
+
+限制客户端连接数量和带宽:
+# frps.ini
+[common]
+bind_port = 7000
+token = yourSecureToken
+max_pool_count = 50
+max_ports_per_client = 10
+
+问题: 客户端报错 "dial tcp x.x.x.x:7000: connect: connection refused"
+解决方案:
+问题: 客户端日志显示 "login to server failed: authentication failed"
+解决方案:
+问题: 服务端启动失败,提示 "bind: address already in use"
+解决方案:
+netstat -tunlp | grep 端口号 查看占用该端口的进程问题: 代理设置正确,但无法访问服务
+解决方案:
+curl localhost:本地端口 测试本地服务问题: 连接经常断开
+解决方案:
+heartbeat_interval = 30
+heartbeat_timeout = 90
+
+问题: 使用custom_domains配置,但无法通过域名访问
+解决方案:
+dig 或 nslookup 命令验证域名解析🔗
+Done.
+ +前言 本文介绍一些家庭组网方案和家庭网络升级方案。
+网络控制器,一般为闭源的成熟方案;起到路由和管理的功能。Wi-Fi发射器,一般不起路由功能,对性能要求不高。点对点拨号上网。光猫只起到光电转换作用,路由工作交给下一级设备。覆盖范围和信号质量大幅提高。Fiber to the Home,小区光纤箱到你家然后下级连网线。Fiber to The Room,光纤到你家然后下级也连光纤。X86设备或Arm设备的小主机刷Openwrt或其他路由系统,一般没有Wi-Fi功能,具有两个以上的RJ45网口,性能较强;带有天线的路由器,带有Wi-Fi,一般为arm或mips设备,搭载板载内存,性能较弱。企业级方案,美观漫游信号好,成本稍高,比较省心;
+
+同上,自定义程度高,适用与有一定技术基础的用户,性价比高;
+一般可以使用集客AC/AP系统。
+
+即为光猫改桥接,软路由PPPoe拨号;这样增加了一层设备,需要谨慎考虑。
+
+光猫一般有Wifi+PPPoE+IPTV+光纤固话功能,如果不想用光猫可以替代为此方案;
+IPTV设置Vlan解决,固定电话设置为转发到个人手机号或取消.
+
+适用与家里预埋的网口不多的情况,无线Mesh需要AX3000及以上同型号路由器;
+也可以将硬路由刷机用Easymesh实现。
+
+适用与有足够的预埋网口,比无线Mesh稳定。
+如果两台路由器之间不能直接连接,则需要有线回程,
+即为弱电箱光猫+有线连接到路由器+连回弱电箱交换机+有线连接到另一台路由器.
+
+比较小众的组网方案,使用电线传输数据,速度不高,容易受到大功率电器的干扰,
+适用与没有预留网口/布线不方便的环境;
+
+++单层楼环境优先考虑Mesh组网,多层楼环境优先考虑AC+AP;
+
++如果要实现全屋2.5G网络,可以直接更换2.5G光猫+带2.5G口下接设备,注意需要宽带套餐/光猫/路由器/网线/终端设备全部支持2.5G才能跑到近似网速;
+
++如果需要2.5G以上更高带宽,则考虑光组网方案,也可以像方案4买相应性能的交换机设备;
+
++不建议使用光猫自带的wifi,光猫同时PPPoE拨号+DHCP路由+发射wifi,性能不够会造成大量发热。
+
光纤方案性能强大,但光纤便宜而光电转换设备贵,而且最终还是要连到RJ45网口或无线,中间需要光转电转换器,性能要打个问号;且后期维护成本高,需谨慎考虑。
+光AC+AP,性能强大,但比较昂贵,自定义程度小;
+
+主副光猫Mesh,性质同上;
+光纤需要考虑光衰,且没有网线耐用,打头工具也比网线贵的多,而且需要注意合约内容;
+当然,也可以在装修阶段就部署光电复合缆,会有更多的选择空间。
+
+路由器是计算机网络中的重要设备,主要用于连接不同的网络,并在这些网络之间转发数据。其工作原理涉及以下几个主要方面:
+1.数据包转发:路由器根据目标地址将数据包从一个网络转发到另一个网络。它通过查找路由表来确定最佳路径,并将数据包转发到正确的输出端口。
2.路由表:路由器维护一个路由表,其中包含了网络的拓扑结构以及到达每个网络的最佳路径信息。路由表可以通过静态配置或动态路由协议(如OSPF、BGP等)自动学习和更新。
3.数据包处理:当路由器接收到数据包时,它会检查数据包的目标IP地址,并根据路由表确定应该转发到哪个端口。路由器还可能执行其他功能,如网络地址转换(NAT)、质量服务(QoS)和防火墙等。
4.连接多个网络:路由器通常具有多个网络接口,可以连接不同的网络。这些网络接口可以是以太网、Wi-Fi、光纤等,使路由器能够在不同类型的网络之间进行数据转发。
5.路由器协议:路由器使用不同的协议来实现数据包转发和路由表的更新。这些协议包括IP协议用于数据包交换,动态路由协议用于路由表的学习和更新,以及其他协议用于网络管理和安全。
一般而言,家用路由器使用 DHCP 模式,由上级网关的网线连接到路由器的WAN口,如小米路由器的192.168.31.1,在浏览器输入此地址可以进入管理界面,并可以发现了解连接该无线网络的设备地址都为192168.31.xx;且路由器的几个Lan口可以做交换机使用。
+路由器的信号好不好,一般而言,与以下几点相关:
+1.路由器支持的协议类型:
+路由器命名常见的格式为AX3000、AC1800等,前面代表协议,后面数字表示速率(Mbps);AX(802.11ax)在相同速率下比AC更快,即Wifi6比Wifi5要好。在相同协议下,一般速率越高越好;千兆优于百兆,但需注意千兆端口和千兆天线的产品。
速度:Wi-Fi 6 比 Wi-Fi 5 更快。Wi-Fi 5 支持的最高速度为1.3 Gbps(理论上),而 Wi-Fi 6 的最高速度为9.6 Gbps(同样是理论上的速度)。这意味着Wi-Fi 6可以提供更快的数据传输速率,特别是在拥挤的网络环境中。
容量:Wi-Fi 6比 Wi-Fi 5具有更好的网络容量管理。Wi-Fi 6采用了一些技术,如 OFDMA(正交频分复用多址)和 MU-MIMO(多用户多输入多输出),使得网络更有效地管理多个设备的连接。这意味着 Wi-Fi 6在拥挤的网络环境中能够更好地处理大量设备的连接,而不会出现性能下降。
延迟与功耗:Wi-Fi 6 比 Wi-Fi 5 具有更低的延迟。通过一些新的技术,如目标唤醒时间(TWT)和 BSS 领导者切换,Wi-Fi 6 能够在连接设备之间实现更快的响应时间和更低的延迟,也可以更有效地管理设备的电量消耗,延长设备的电池寿命。这对于需要快速响应的应用,如在线游戏和视频会议,尤其重要。
在 Wifi6 普及的当下,建议购买 WiFi6 路由器,并且此类路由器往往还带有 wifi5 备用网络,可与老旧设备兼容,不必担心。小心百兆网口和千兆天线的牛马产品!
++目前Wifi7设备逐渐推出,但在中国大陆地区大部分频段被划分给5G使用,Wifi7实际的提升微乎其微。
+
2.路由器支持的速率:
+不要盲目追求大数字:路由器标注的无线速率是叠加速率,并非单一设备接入的最大速率。例如,标注为1750Mbps的路由器,实际上是由2.4GHz的450Mbps和5GHz的1300Mbps相加而成,单一设备的最大通信速率只有1300Mbps。大多数家庭接入的光纤速率为千兆(1000Mbps),因此最大速度为125MB/s,因此瓶颈通常不在于路由器性能;选购家用路由器,更重要的是提高信号覆盖面积和强度,能跑满千兆已经不错。
3.路由器的无线频段:
+2.4GHz频段稳定性高,覆盖范围广,穿墙能力强;而5GHz频段速度快但穿墙能力较弱;
4.无线网络的频段带宽:
+2.4G有20Mhz和40Mhz两种频道带宽,5G则有80Mhz和160Mhz两种;频道带宽就是发射频率的宽度,带宽越低穿透性越好。如果连的设备多的话,就用低频段;
5.芯片的主频和板载内存
+路由器处理器的主频越高,加解密性能越好,速度和带机量也更大;目前低价位路由器通常使用MTK、瑞昱、海思等廉价处理器,配以64MB/128MB的内存。而高端路由器多使用博通的高端芯片,在内存的配置上往往可以达到256MB以上。博通高端芯片在各个方面表现都不错,同时各位大神对刷机的支持力度也比较大。板载内存越大可为后续刷机留下空间,并支持插件等;
6.其他功能
+如 QOS,设备管理,IPTV 支持,IPV6 等等;
+++天线越多信号不一定越强。
+
路由器的发射范围是由协议决定的,与根数无关。对于双频的路由来说,4根或者6根其实只有一半(2根2.4g和2根5g使用)。
+++无线功率不是越大越好。
+
因为无线通信是双向的,路由器功率大了,但是你的手机等无线终端设备功率是不变的。在符合国家标准的情况下,wifi 功率是有硬性标准的,单台路由器覆盖80平以上的面积不太现实。因此当你面对信号差、覆盖死角的时候,应该首要想到的是增加覆盖节点,而不要相信宣传所谓的“穿墙王”。
1. 网线选择建议:
+在考虑网络建设方面,从经济效益角度而言,超五类网线已经足以满足大多数家庭的千兆网络需求(1Gbps)。在短距离内,质量较高的五类/超五类网线支持高达2500兆的传输速率(2.5Gbps)。因此,一般情况下,考虑到成本因素,建议家庭网络布线选用符合标准的超五类网线。
若愿意适度增加布线成本,则推荐选择支持万兆(10Gbps)网络的六类/超六类以上网线,尤其是从光猫到主路由/交换机的这一段线路,最好支持万兆。即便今后需要扩展网络速度无法满足万兆的有线条件,也可以通过 Wi-Fi7 标准实现无线超万兆速度覆盖。
+2. 网线布线注意事项:
+在进行网线布线时,无论是屏蔽网线还是非屏蔽网线,都应确保将强电线和弱电线分开放置于不同的管道中。同时,在走线过程中应保持一定的间距,以减少干扰。若需要考虑未来更换网线的情况,建议选择更大的穿线管道,并确保每条网线单独走一根管道。若出现强、弱电交叉走线的情况,可采用铝/锡纸包裹弱电管道以实现简单的屏蔽作用。应避免与大功率强电线相交或并行走线,如空调、烤火炉、微波炉等。
3. 弱电箱至电视柜网线布线:
+考虑到当前电信运营商提供的IPTV功能,如果不熟悉设置VLAN的单线复用,或者未来可能使用到链中聚合技术,建议从弱电箱至电视柜至少布置两条网线,以免后悔。
4. 接线盒的预留:
+许多人可能认为随着21世纪的到来,有线布线已经过时。因此,为了节约成本或受装修公司的误导,一些卧室甚至书房都没有进行网线布置,这是不可取的。无线网络虽然方便,但速度远不如有线快速稳定。因此,建议在每个卧室的相应位置安装一个网线接线盒,并在墙壁上安装电视时,下方也应预留一个网线接线盒。如果有地下室或楼阁,也应该布置一条网线。多预留一些接线盒总比今后发现需要网线却没有的尴尬情况要好。
5. 死角位置的网线和电源接口预留:
+对于信号死角的位置,根据实际情况,如阳台、露台等不需要路由器设备可见的地方,可以考虑将路由器隐藏在吊顶中,甚至包括厕所的吊顶也可以考虑。在这些位置预留多个网线和电源接口是明智的选择。
+6. 路由器放置位置推荐:
+一般来说,家庭会将路由器放置在弱电箱或电视柜内,然而,周围其他电器设备运行时会产生电磁干扰,对2.4G和5G信号都会造成影响,甚至蓝牙设备也会有干扰。基于信号向下传播的特性,建议将路由器放置在较高位置,如吊顶内或进门处的高处,并最好选择居住区域的中心位置以实现更好的信号覆盖。
前言 本文介绍常用的家庭网络测试方法,包括开源固件和闭源商用设备的测试。
+ +随着Wi-Fi7设备的逐渐普及和家用路由器的性能提升,百元以内的wifi6路由器性价比变得非常高,可以用非常少的预算搭建高速网络;然而即使是同样的方案,各家路由器的实际体验却不一致,因此这里记载一些测试路由器性能的方法。
+开源固件如OpenWrt,无论是软路由还是硬路由都很方便测试。为了方便测试,我们假设你的网络拓扑为简单的光猫+无线路由器;实际使用中自上而下的,运营商的套餐带宽/限速/QOS,设备的转发性能和网线/网卡的质量都会引起整个网络的波动。
+| 指标 | 含义 |
|---|---|
| 吞吐量(Throughput) | 最大数据传输速度 |
| 延迟 / 抖动 | 延迟和波动情况 |
| 转发性能 / pps | 每秒能转发多少数据包 |
| 并发连接数 | 同时建立多少TCP连接 |
| NAT / 防火墙性能 | 打开转发、NAT、规则后的性能 |
带宽,也叫吞吐量,是我们最为关心的一个性能指标之一。
+理论上1000兆宽带的极限下载速度为125MB每秒,实际上日常生活中少有跑满带宽的使用情况,毕竟商用服务器的带宽成本高,比如B站的视频降码率等等。对于极客玩家来说,内网文件共享,游戏串流,NAS服务和外网多线程下载,BT下载等等需要比较高的带宽性能。以下是一些常见的测试方法:
+开源固件可以使用iperf3来测试。
+在路由器A上和设备B上安装iperf3,openwrt为opkg install iperf3,随后在A上使用命令iperf3 -s开启服务端;在B上使用命令iperf3 -c <A的IP>,即可测试B到A的TCP单线程上传速率(本地带宽),应该和A的物理端口速率相近。若要测试下载速率,iperf3 -c <A的IP> -R即可。
TCP单线程下载测试示例:
+
如果你的路由器为闭源固件,也可以到在线测速站进行简单测试:
+ +这些网站的测试速度随着节点的不同而有所差异,比如测试节点在北京联通而你是广东电信,会和实际差距较大。当然,还有一个简单权威的方法,就是下载一个Steam上的大型游戏,Steam的节点在任何国家基本都可以跑满。
+简单的ping命令即可测试延迟,对网络排除故障很有帮助。ping命令是一个广泛使用的命令,在各种系统上都有。
+使用ping <目标IP> -c 20命令进行测试,可以看到min/avg/max三个值,即为最小/平均/最大延迟;

也可以使用iperf3来测试UDP抖动:使用命令iperf3 -c <server_ip> -u -b 100M -t 10,-u表示使用udp,-100M表示使用100兆带宽,可逐渐调高并接近极限性能。

路由器的CPU作为核心,需要处理外网与内网IP的转发,这种转发能力称为包转发率,通常拿小包的转发率来衡量能力的高低。测试“小包转发能力”其实就是测试 PPS(Packets Per Second)能力,在x86软路由上面这个性能尤为重要,因为无线路由器有硬件级别的加速芯片而软路由没有。
+++以单位时间内发送64byte的数据包(最小包)的个数作为计算基准的。对于千兆以太网来说,计算方法如下:1,000,000,000bps/8bit/(64+8+12)byte=1,488,095pps,说明:当以太网帧为64byte时,需考虑8byte的帧头和12byte的帧间隙的固定开销。故一个线速的千兆以太网端口在转发64byte包时的包转发率为1.488Mpps
+
测试转发性能需要发包-转发-收包三台设备,或者使用环回测试仪。由于iperf3 处于 TCP/UDP 层,包也会变大且加了协议头,测试的结果误差很大,因此不建议用其进行测试小包性能。
+未完待续。
+ +前言 在互联网的日常使用中,电子邮件作为一项基础服务扮演着重要的角色。尽管在过去几十年里出现了各种新型的通讯方式,但电子邮件仍然保持着其不可替代的地位。了解电子邮件的工作原理,有助于更好地理解这一基础服务是如何运作的。
+与许多其他基于协议的应用一样,电子邮件依赖于一系列协议来进行传输和交换。而基于协议的应用一般不会轻易地被历史淘汰:在过去的几十年里,基于 HTTP 上层的网站,以及技术更新换代了好几波,但底层的协议依然还是 HTTP(HTTPS)。基于 BitTorrent 协议的文件交换协议,和基于SMTP(Simple Mail Transfer Protocol)的电子邮件传输便是其中之一。
+电子邮件的发送过程可以简单地描述为以下几个步骤:
+撰写并发送一封邮件。使用SMTP协议将邮件发送到相应的邮件服务器。DNS查询MX记录找到接收方的邮件服务器。为了确保通信安全,电子邮件的发送还引入了一些安全机制,如SPF、DKIM和DMARC。
+SPF(Sender Policy Framework)用于验证发件人的身份,防止发件人伪造。DKIM(DomainKeys Identified Mail)通过数字签名验证邮件的真实性。DMARC(Domain-based Message Authentication, Reporting, and Conformance)结合了SPF和DKIM,提供了更严格的邮件验证机制。假设用户 a@gmail.com 发送一封邮件到 b@qq.com,会执行如下的流程。
+1.查询 MX 记录
+当我们在 Gmail 网页上撰写一封邮件,并点击发送按钮之后。Gmail 会用自己的内部协议链接 Gmail 的 Outgoing SMTP 邮件服务器。
+Outgoing SMTP 验证用户权限,然后将邮件以 MIME 格式发送到发送队列中。
Gmail SMTP 服务器会通过 DNS 查询到域名 qq.com MX(Mail Exchanger) 记录(dig MX qq.com),找到邮件服务器的 IP 所在。
在 Linux 下也可以通过 dig mx qq.com 来查询到。这一步在对应到自建的邮件服务器的时候,就是通过配置 DNS 的 MX 记录来实现的。
+一般情况下会配置一个 A 记录 mx.example.com 指向服务器的 IP 地址。然后再配置一个 [[MX 记录]],@ 全部域名的 MX 请求全部转发给 mx.example.com。
+2.SMTP 发送
+当 Gmail 的服务器找到 QQ 邮箱的 IP 地址之后,邮件就会通过 SMTP(Simple Mail Transfer Protocol ) 协议连接服务器的连接,尝试发送给 QQ 的服务器。
+为了简化理解,SMTP 传输的时候就直接声明,我 a@gmail.com ,我要发送邮件到 b@qq.com ,内容是某某某。QQ 邮箱的服务器接收到 Gmail 的邮件之后,再根据用户名决定发给具体谁的邮箱。
+这中间会发现不存在任何验证发送方身份的过程,这也就意味着任何人都可以伪装一个任意的发送邮箱以一个伪装的邮箱发送邮件。SMTP 最早是建立在相互信任的基础之上的,所以也给后面的恶意使用留下了一些漏洞,为了修复这个漏洞发明了 SPF。
+3.SPF 验证
+上文提到过 SMTP 协议发送邮件的过程中没有验证发送方,这也就意味着发信方可以任意指定发件人邮箱地址,这会存在一些安全问题。
+具体来说,本来我的 Gmail 邮箱是 a@gmail.com,假如有不法分子,就可以利用这个漏洞,伪装成自己是 a@gmail.com 给别人发送邮件。
[[SPF]] 的目的就是为了防止伪造发信人。
+SPF 的实现原理非常简单,就是通过添加一条 DNS 记录。
+如果邮件服务器收到一封来自主机 1.1.1.1 的邮件,并且发件人是 a@gmai.com,为了确认发件人,邮件服务器就会去查询 gmail.com 的 SPF 记录。如果域名设置了 SPF 记录,允许 1.1.1.1 的 IP 地址发送邮件,那么收件的邮件服务器就会认为邮件是合法的,否则就会退信。
有了 SPF 记录之后,如果有人想要伪装成 a@gmail.com 他既不能修改 gmail.com 的 DNS 解析,也无法伪造 IP 地址,就有效的防止了伪装。
在自建邮件服务器的时候,经常会让我们设置一个 TXT 记录,配置值为 v=spf1 mx ~all,这表示的意思是允许当前域名的 MX 记录对应的 IP 地址。
下面再举个非常常见的例子:
+v=spf1 a mx ip4:173.10.10.10 -all
+
+表示允许当前域名配置的 A 记录,MX 记录的 IP 地址,以及一个额外的 IP 进行发信。
+SPF 机制可以有效地规避了发送邮件方伪造发件人的问题。但实际使用的时候,如果你使用多个邮箱,然后设置了其中 c@163.com 邮箱自动转发到 a@gmail.com 中。
+那么这个时候如果 b@qq.com QQ 邮箱发送了一封邮件到 c@163.com 邮箱,163 邮箱原封不动地将邮件转发到 Gmail 邮箱,这个时候发件人是 b@qq.com,但是 Gmail 回去查询 qq.com 的 SPF 记录,但会发现并不包含 163 邮箱的 IP 地址,会误判转发的邮件;所以又诞生了 DKIM。
4.DKIM
+DKIM (DomainKeys Identified Mail) 的缩写,允许发送者通过在邮件的 header 中包含一段数字签名来验证邮件。DKIM 使用公私密钥来确保邮件内容是从授信的邮件服务器发送的。
+还是利用上面的例子,因为我们把所有发送到 163 邮箱的邮件都转发到了 Gmail 邮箱,所以来自 QQ 邮箱的邮件在验证 SPF 时会失败。
+那么在 DKIM 中,发送邮件的服务器,比如 QQ 邮箱,会使用公私钥对邮件内容进行签名,并将签名和邮件内容一起发送。当 Gmail 收到从 163 邮箱转发过来的 QQ 邮箱邮件的时候,就会去查询 qq.com 的 DNS 记录,拿到公钥。然后使用公钥和签名来验证邮件内容。如果验签不通过,则将邮件判定为伪造。
5.DMARC
+经过了 SPF 和 DKIM 的保证,是不是就可以完美的发送接收邮件了?其实并不能,我们通过邮件后台来看一下邮件的原始文本。
+MIME-Version: 1.0
+Return-Path: xxx@fake.com
+DKIM-Signature: d=fake.com,b=adceabkekd12
+Date: Tue, 22 Mar 2022 06:37:58 +0000
+Content-Type: multipart/alternative;
+ boundary="--=_RainLoop_587_997816661.1647931078"
+From: admin@a.com
+Message-ID: <a67d96a38592cdad46cca89e98dda26d@techfm.club>
+Subject: Seems it works
+To: "Somebody" <a@gmail.com>
+
+
+----=_RainLoop_587_997816661.1647931078
+Content-Type: text/plain; charset="utf-8"
+Content-Transfer-Encoding: quoted-printable
+
+~~
+
+----=_RainLoop_587_997816661.1647931078
+Content-Type: text/html; charset="utf-8"
+Content-Transfer-Encoding: quoted-printable
+
+<!DOCTYPE html><html><head><meta http-equiv=3D"Content-Type" content=3D"t=
+ext/html; charset=3Dutf-8" /></head><body><div data-html-editor-font-wrap=
+per=3D"true" style=3D"font-family: arial, sans-serif; font-size: 13px;"><=
+br>~~<signature></signature></div></body></html>
+
+----=_RainLoop_587_997816661.1647931078--
+
+
+SPF 解决了接收方验证发件人域名 SPF 记录内 IP 地址从而验证发件人的问题。但是因为 SPF 定义的发件人是 RFC5321 协议中规定的 Return-Path,而 DKIM 在邮件头中直接包含了域名,只要使用该域名的公钥验证通过即可。
+而现在的邮件服务给用户展示的发件人都是 From 字段,而不是 SPF 的 Return-Path,也不是 DKIM 的 DKIM-Sginatur: d=,所以攻击者可以通过伪造这两个字段,发送如上的邮件,完美通过 SPF 和 DKIM 检查,因为 SPF 检查 Return-Path 而 DKIM 验证的 d= 也是 fake.com 所以最终用户看到的发件人却是 admin@q.com。
所以就诞生了 DMARC。DMARC 结合了 SPF 和 DKIM,规定了 Return-Path 和 DKIM-Signature: d= 两个至少需要有一个与 From 头对应,否则判定为失败。
当邮件服务器接收到邮件时,先验证 DKIM,SPF,然后再根据 DMARC 的配置检查。这样就能确保最终用户看到的 From 字段和 SPF、DKIM 认证的发件人一致了。
POP3、IMAP 和 SMTP 是用于电子邮件传输的常见协议和服务,这些协议共同构成了电子邮件系统的基础,允许用户接收、发送和管理电子邮件。
+这是每个协议的简要技术原理:
+区别:
+功能:
+邮件管理:
+端口号:
+操作方式:
+共同点:
+用途::它们都是用于电子邮件传输的标准协议。
+与邮件服务器的通信::它们都涉及客户端与邮件服务器之间的通信。
+身份验证::它们都需要用户身份验证来访问邮箱。
+发送方(发件人):
+撰写邮件: 发件人使用邮件客户端(如Outlook、Gmail等)撰写邮件,并填写收件人的电子邮件地址、主题和邮件内容。
+SPF 检查: 发送邮件服务器可能会执行 SPF(Sender Policy Framework)检查。它查询发件人域名的 DNS 记录,以确认发送邮件的服务器是否被授权发送邮件。
+DKIM 签名: 发送邮件服务器对邮件进行 DKIM(DomainKeys Identified Mail)签名。它使用发件人域名的私钥对邮件进行加密签名,以确保邮件内容在传输过程中不被篡改。
+SMTP 发送邮件: 发送邮件服务器使用 SMTP(简单邮件传输协议)将邮件发送到接收邮件服务器。SMTP 服务器与接收邮件服务器之间建立连接,并通过指定的端口(通常是 25 端口)传输邮件。
+接收方(收件人):
+SMTP 接收邮件: 接收邮件服务器接收到发送方发送的邮件。SMTP 协议负责将邮件从发送方传输到接收方。
+SPF 验证: 接收邮件服务器执行 SPF 验证,检查发送方服务器的 IP 地址是否在发件人域名的 SPF 记录中被授权发送邮件。
+DKIM 验证: 接收邮件服务器对收到的邮件执行 DKIM 验证。它使用发件人域名的公钥来验证邮件的 DKIM 签名,以确保邮件内容的完整性和真实性。
+DMARC 检查: 如果接收邮件服务器支持 DMARC(Domain-based Message Authentication, Reporting, and Conformance),它会执行 DMARC 检查。DMARC 结合了 SPF 和 DKIM,允许域名所有者指定如何处理未通过验证的邮件。
+投递邮件到邮箱: 如果邮件通过了所有的验证步骤,并且没有被识别为垃圾邮件,接收邮件服务器将把邮件投递到收件人的邮箱中。
+邮件获取(收件人):
+POP3 获取邮件(可选): 收件人可以使用 POP3(邮局协议版本3)从邮件服务器上下载邮件到本地设备。POP3 客户端通过指定的端口(通常是 110 端口)连接到邮件服务器,并下载邮件到本地设备上。根据设置,邮件可能会从服务器上删除。
+IMAP 获取邮件(可选): 收件人可以使用 IMAP(互联网邮件访问协议)从邮件服务器上获取邮件。IMAP 允许邮件保留在服务器上,并且在多个设备之间同步邮件状态。IMAP 客户端通过指定的端口(通常是 143 端口)连接到邮件服务器,并获取邮件列表和邮件内容。
+Done.
+ +前言 poste.io 邮件服务基于 Docker 搭建,用的是 Haraka + Dovecot + SQLite 邮件系统,占用资源较少,安装简单,适合个人使用。
+hostnamectl set-hostname mail.your-domain.com
+
+vim /etc/hosts
+
+添加一行
+127.0.1.1 localhost.localdomain mail.your-domain.com
+
+docker compose文件示例:
+version: '3.7'
+
+services:
+ mailserver:
+ image: analogic/poste.io
+ hostname: mail.your-domain.com
+ ports:
+ - "25:25"
+ - "110:110"
+ - "143:143"
+ - "587:587"
+ - "993:993"
+ - "995:995"
+ - "4190:4190"
+ - "465:465"
+ - "127.0.0.1:8808:80"
+ - "127.0.0.1:8843:443"
+ environment:
+ - LETSENCRYPT_EMAIL=admin@your-domain.com
+ - LETSENCRYPT_HOST=mail.your-domain.com
+ - VIRTUAL_HOST=mail.your-domain.com
+ - DISABLE_CLAMAV=TRUE
+ - TZ=Asia/Shanghai
+ - HTTPS=OFF
+ volumes:
+ - /etc/localtime:/etc/localtime:ro
+ - ./mail-data:/data
+
+禁用反病毒功能(DISABLE_CLAMAV=TRUE)、禁用反垃圾邮件功能(DISABLE_RSPAMD=TRUE),可以大幅减低内存和CPU占用,请酌情设置禁用选项。
+禁用WEB收发功能(DISABLE_ROUNDCUBE=TRUE),可以进一步减少资源占用,不过非必要不建议禁止。
+8808为http端口,可以根据自己的需求修改。
+| 记录类型 | 主机记录 | 记录值 |
|---|---|---|
| A | 1.2.3.4 (your ip) | |
| MX | your-domain.com | mail.your-domain.com |
| TXT | your-domain.com | v=spf1 mx ~all |
| TXT | _s20160910378._domainkey.your-domain.com | k=rsa;p=MII......... |
| TXT | _dmarc | v=DMARC1; p=none; pct=100; rua=mailto:mail@your-domain.com |
| CNAME | imap | |
| CNAME | smtp | |
| CNAME | pop |
最后还需到 VPS 服务商处添加一个反向 DNS,也就是 rDNS 解析,把 IP 解析到 mail.your-domain.com 这个域名,有些 VPS 商家不提供这种服务,所以需要选择好VPS服务商。
+通过浏览器访问https://mail.your-domain.com/admin/login进入poste.io的配置页面,按照提示进行配置,然后点击 Generate new key,生成 key,添加到 DNS 解析记录,就是上面最后一条解析_s20160910378._domainkey.your-domain.com
搭建完毕之后我们也可以通过客户端软件连接到我们的邮箱,如thunderbird.
+| 协议 | 服务器地址 | 端口 | SSL |
|---|---|---|---|
| SMTP | mail.your-domain.com, smtp.your-domain.com | 25, 465, 587 | STARTTLS |
| IMAP | mail.your-domain.com, imap.your-domain.com | 993, 143 | STARTTLS |
| POP3 | mail.your-domain.com, pop.your-domain.com | 995, 110 | STARTTLS |
Done.
+ +前言 本文主要探讨的是IPv4网络,国际出口线路的质量分析以及各大ISP的介绍。
+163骨干网(ChinaNet):走AS4134路由节点,IP开头一律是“202.97..”,全程不经过CN2网络节点,已知出口有:北京、上海、广州
CN2:中国电信下一代承载网,简称CN2;CN2分为CN2 GT和CN2 GIA:
CN2 GT(Global Transit 又称半程 CN2 )国内走163骨干网,国际走CN2.CN2GIA (Global Internet Access 又称纯 CN2/全程 CN2)全程不经过163骨干网,走AS4809路由节点,IP开头一律是“59.43..”,已知出口:北京、上海、广州、乌鲁木齐.联通169网络(CHINA169):由原中国网通互联网骨干网(CHINA169)和原中国联通互联网骨干网(UNINET)合并而来,全程走AS4837的路由节点,IP开头一律是“219.158..”,已知出口:北京、上海、广州
联通A网(CUII)经常被称为9929网络:走AS9929路由节点,IP开头一律是“218.105../210...*”,对标电信CN2 GIA,已知出口:北京、上海、广州
联通国际CUG:走AS10099路由节点,提供至大陆方向的差异化接入,包括 CUG(AS10099 -> AS4837)和 CUG VIP(AS10099 -> AS9929 -> AS4837)
联通的线路组合主要有以下几种:
+内地 AS4837 + 境外 AS4837:最普通、最常见的联通 169 网络,也是一般联通家宽路由线路。内地 AS4837 + 境外 AS10099:应该算是高端线路,目前看到搬瓦工香港 CN2 GIA 是这样走的。内地 AS9929 + 境外 AS4837:目前暂时没看到这种路由,但是看到介绍说部分地区 A 网出境后会并入 169 网。内地 AS9929 + 境外 AS10099:联通高端线路,China Unicom Premium。中国移动骨干网:国内必走AS9808路由节点,IP开头一律是“221.176../221.183..”,部分会并入到原铁通 AS9314 / 电信 163 骨干网 / 联通 169 骨干网,已知出口:北京、上海、广州
国际段骨干网(CMI):AS58453路由节点,承接所有AS9808出镜流量
中国教育网:走AS4538路由节点,各大高校的校园网和部分大型国内云服务提供商,已知出口:北京清华大学
NextTrace 是一款开源的可视化路由跟踪(Traceroute)工具,支持 IPv4/IPv6,以及 ICMP、TCP、UDP 多种协议,可生成终端表格、JSON 输出,甚至可在线展示地图路径。它兼顾了轻量化与可视化展示的需求,非常适合网络工程师和运维人员进行链路排查与延迟分析。
++ ++
# IPv4 ICMP 路由跟踪
+nexttrace 8.8.8.8
+
+# 指定输出为 JSON
+nexttrace --json www.google.com
+
+# TCP 路由跟踪到 443 端口
+nexttrace --tcp --port 443 2001:4860:4860::8888
+
+# 开启多探测包和并发
+nexttrace --queries 3 --parallel-requests 4 example.com
+
+# 显示表格输出并关闭反向解析
+nexttrace --table --no-rdns www.example.org
+
+❯ nexttrace 38.207.170.5x
+NextTrace v1.4.0 2025-04-16T01:10:07Z dccc41b
+[NextTrace API] preferred API IP - 198.18.0.61 - 601.41ms - 🐠 (Relay) → Misaka.HKG
+IP Geo Data Provider: LeoMoeAPI
+traceroute to 38.207.170.5x, 30 hops max, 52 bytes payload, ICMP mode
+1 192.168.1.1 * RFC1918
+ 3.80 ms / 2.75 ms / 3.37 ms
+2 192.168.0.1 * RFC1918
+ 4.14 ms / 5.40 ms / 6.76 ms
+3 100.64.0.1 * RFC6598
+ 11.22 ms / 12.22 ms / 13.40 ms
+4 *
+5 *
+6 *
+7 *
+8 202.97.66.213 AS4134 [CHINANET-BB] 中国 广东 广州 www.chinatelecom.com.cn
+ 22.25 ms / 21.00 ms / 20.69 ms
+9 *
+10 218.30.53.134 AS4134 [CHINANET-US] 美国 加利福尼亚 洛杉矶 CT-POP-Zenlayer www.chinatelecom.com.cn 电信
+ 174.40 ms / 173.56 ms / 173.49 ms
+11 10.163.0.2 * RFC1918
+ 173.78 ms / 174.93 ms / 174.35 ms
+12 *
+13 38.207.170.5x AS979 美国 加利福尼亚州 洛杉矶 as979.net
+ 176.31 ms / 177.14 ms / 174.71 ms
+MapTrace URL: https://assets.nxtrace.org/tracemap/30cce0c3-18a6-582c-8679-xxxxxxxxxx.html
+
+BGP专线:简单来说BGP线路就是一个能够动态切换的线路,当一条线不能正常链接访问时,自动切换到另一条线路。BGP线路简单来说就是将电信、联通、移动、铁通、教育网等多家运营商的网络融合在一起的线路,融合为一个IP地址,路由器根据相关数据进行解析,选出最快的线路反馈回去,以实现不同线路之间的互联互通。
CN2:CN2线路是中国电信推出的一种优质线路,又叫中国电信下一代承载网。是中国电信目前推出的质量最好的网络带宽线路。主要特点:低丢包、低延时、轻负载,出国回国必定经过北京/上海/广州。
CN2 GT: CN2里属于Global Transit的产品(又名GIS-Global Internet Service),在CN2里等级低,省级/出国节点为202.97开头,国际骨干节点有2~4个59.43开头的CN2节点。在出国线路上拥堵程度一般,相对于163骨干网的稍强,相比CN2 GIA,性价比也较高。出国前走的是163骨干网,出国后走的是59.43开头的
CN2 GIA: CN2里属于Global Internet Access的产品,等级最高,省级/出国/国际骨干节点都以59.43开头,全程没有202.97开头的节点。在出国线路上表现最好,很少拥堵,理论上速度最快最稳定,当然,价格也相对CN2 GT偏高。
IPLC和IEPL:
IPLC是英文词组”International Private Leased Circuit” 的缩写,即“国际专线”,是指用户专用的跨国的数据、话音等综合信息业务的通信线路。通俗地说,也就是指传统的专线,如DDN、E1等,用于互连两点之间的通信,只不过IPLC是跨国跨境专用的而已。比如深港IPLC,即深圳到香港点对点传输而不经过公网,是完全的内网,可以被认为是真正意义上的专线。这种专线因为没有走公网因此完全不过墙,你传输什么 GFW 都是不会知道的。
IEPL是英文词组“International Ethernet Private Line”的缩写,即“国际以太网专线”。IEPL线路为二层的电路,主要为跨国性企业提供高品质的以太网专线服务。国际以太网专线服务(IEPL)为一个端对端的管理式频宽服务方案,透过网络平台,为客户提供可作无限扩充的点对点专用跨境通讯服务。IEPL网络传输性能优于专线IPLC,但是价格也比IPLC一般企业和个人用户更贵,IPLC和IEPL专线使用体验差别不大,IPLC性价比更高。个人使用。IPLC比IEPL对于企业实时合作办公络游戏加速的高端用户来说,专线更划算,IEPL专线会有比IPLC低延迟体验更好。
QoS是什么?
+QoS(Quality of Service)是一种网络技术也可以理解为数据的分拣中心,用于在网络上为不同的应用程序或用户提供不同的服务质量。它可以确保网络上的数据传输是可靠的,并且可以根据需要分配带宽和优先级。简单的理解就是在上网高峰期,它会选择性丢包,确保重要客户或者重要信息优先通行,例如在上网高峰期一般个人用户和企业用户,企业用户的优先级就高于我们个人用户,跟银行的VIP客户原理一样。
常见运营商:CMI、CUG、NTT、PCCW、Telia、Telstra、CHT、HKBN、HKT、WTT、HGC、GTT、TaTa、HE、Cogentco、SingTel
+常见数据中心:HKIX、EIEHKG(Equinix Internet Exchange HongKong)
+常见下游:Cloudflare、Amazon、Azure、Google、CDN77、Cera Network
+对于很多南方地区的用户来说,对于需要访问一些全球类的网站,离得最近的CDN网络都是在香港(延时最低)。香港机房一直都是很多面向亚太地区服务器托管商的兵家必争之地,所以也涌现出了大量的IDC商家,可惜鱼目混杂,能做到价格便宜且到国内直连的却少之又少,直连高昂的宽带单价也劝退了大部分商家。
+由于CMI自己也在卖香港资源,所以有些下游会选择直接购买CMI的Transit,来获得高Qos的CMI体验,这样国内用户到这些下游提供商就可以全部走移动的骨干网,来获得高性价比且高质量的访问体验。
+++境内连接质量:非常高,只要对方下游接入了足够的CMI Transit宽带,峰值宽带基本是移动保证的。无论是电信、联通还是移动(当然移动用户访问过去,优先级是最高的)。虽然高性价比,但是毕竟是香港地区,流量单价依旧远超美欧Transit的单价。
+
同移动的CMI,联通也卖香港资源(自治系统编号AS10099),很多下游也选择接入了CUG的资源,这对于联通用户来说,等于获得了很好的质量保证。
+++境内连接质量:非常高,只要对方下游接入了足够的CUG Transit宽带,峰值宽带基本是联通保证的。无论是电信、联通还是移动(当然联通用户访问过去,优先级是最高的)。
+
可直连的国内骨干网:AS4809、AS58453
在香港地区,只有电信CN2、移动可以直连,其中电信CN2买了NTT Transit 。其余电信163和联通169都会绕路日本和美国。
+移动如果不买他们的商业高Qos宽带,在高峰时期直连NTT会被Qos,丢包和延时都会显著增加,速度一般无法超过10Mbps。对于高Qos的移动用户也并不乐观,高峰时期,因为上海和广州地区汇聚层拥堵显著,所以最高速率往往也无法超过200Mbps;特殊CM2精品网大客户除外,因为你加钱买了VIP。
+++连接质量:需要注意的是,CN2很多时候不是万能的,特别是香港地区。CN2到香港NTT不可靠,有时候会爆炸,延时会呈现剧烈的抖动,如果需要追求高稳定性,不推荐CN2用户使用接入香港NTT的网络。
+
可直连的国内骨干网:AS4134、AS4809、AS4837、AS9929、AS58453
我们平时接触PCCW的机会很多,PCCW也有一个负责国际优化的网络PCCWG (G=Global),我们平时遇到的商家一般接入的都是PCCW(非含G的网)。其实PCCW的效果在平时是被夸大的,就算是线路可以直连实际综合连接效果也仅仅是一个平均水平。
+电信163(AS4134)到香港PCCW是否直连看本地电信网络是否有自己的AS号,比如北京电信的AS4847城域网,上海电信的AS4812城域网等。一般来说,如果该地网络有自己的城域网AS号专门管辖,除非商家有特别优化,那么一般到香港PCCW不直连,否则如果是直接位于AS4134上一般会直连。电信网络到PCCW一般只有北京和广州两个汇聚层可达,上海汇聚层不可达,高峰丢包较高,速度不理想。
+联通169(AS4837)联通到香港PCCW可能绕美,原因和电信部分相同,不再赘述。直连的情况下,联通到PCCW效果要远远好于电信,处于可用的状态。
+联通A网(AS9929) 网络质量基本是这么多网络里面连接到PCCW最好的,延时抖动也是最低的。但是9929的价格比CN2都要贵上好多倍,一般没有点钞能力是用不上的…
+移动的CMI(AS58453),如果没有商家优化,移动会随机把路由发往美国、日本、香港三地,以实现流量平衡,在用户看来,这就导致延时时高时低,非常不稳定,不推荐移动使用。
+同时,HKT隶属于PCCW,所有的国际出口都是走PCCW/PCCWG的。HKT因为可以走上PCCWG和德国地区直连,所以也被称之为打机神线。但是普通的HKT家宽/静态根据段不一样,联通169可能绕韩国KT,也有可能直连(联通9929通过PCCW与HKT互联)。
+可直连国内骨干网:AS4134、AS4837、AS58453
CHT即中华电信,为中国台湾的第一大运营商,拥有2大骨干网(CHW「 HINET」、TWGATE),我们通常说的Hinet即为CHW网络,CHW与TWGATE的关系可以参照电信163和CN2的关系。
+事与愿违,不知道开始,电信163骨干网到CHW网络的效果急转直下,无论是低峰还是高峰的下载速度都只能用惨淡来形容。所以除非你有业务需求,否则我不推荐你把个人网站放在CHW下,高昂的成本价格现在无法匹配上其延时和速度,是个性价比很低的选择。
+相比于电信163的拉垮表现,联通169的表现就漂亮的多,差不多的延时却有着更低的丢包,更高的峰值速度。但是鉴于该地区很高的主机售价,如果你是一个联通用户,CHW也未必是最佳的选择。
+也别对移动CMI抱有太大的期望,在低峰和高峰表现截然不同,高峰常常极度拉垮,上面的Telstra好歹还是有速度,这个是真的一点速度都跑不出来,不推荐。
+常见运营商:HiNet、TFN(台湾固网)、SeedNet、TaNet(台湾学术网络)、HomePlus(中嘉宽频)
+常见数据中心:TWIX
+HINET
+可直连国内骨干网:AS4134、AS58453、AS4837
其中 电信 和 联通 延迟都明显要比移动高一些。
+HiNet是中华电信(CHT)的一个品牌,也是全台湾最大的宽带提供商。目前台湾地区的主流流媒体解锁都是用了HiNet动态IP(家宽)以及静态IP(商宽、IDC)来解锁的。HiNet拥有整个台湾地区最大的电信骨干网,也是国内出口流量最大的ISP。CHT另拥有一张TWGate的网络,专注国际互联,其性质相当于中国电信的CN2。
+常见运营商:NTT、IIJ、KDDI、BBTEC、Telstra、PCCW、BGP.NET
+常见数据中心:JPIX、BBIX、EIEHND(Equinix Internet Exchange Tokyo)
+常见下游:Cloudflare、Amazon、Azure、Google、M427、xTom(搬瓦工是他的下游)
+日本的宽带业务竞争激烈,导致ISP提供商不得不杀出更低的价格来吸引客户,但是往往事与愿违——用户的口碑却更糟糕了。比如,和阿里巴巴合资的SoftBank(软银)公司创立的ISP服务商——BBTEC,看起来是一个不错的选择,实际晚高峰网络拥堵,体验很差劲。
+不仅是家宽,商宽乃至服务器机房,接入一条ISP线路的成本价格都不菲,况且很多日本IDC只对日本本国居民提供服务,所以催生了很多代办业务,最有名的就是樱花机房的服务器代办服务。往往只有这些对本土开放的IDC才有可能是原生IP(可以解锁当地的众多流媒体、游戏和网站)。
+可直连国内骨干网:AS4134、AS4809、AS4837、AS9929、AS58423
日本作为NTT的大本营,几乎全国的宽带服务提供商都有NTT的踪迹。因为NTT的骨干网覆盖了日本几乎所有能够覆盖到的地区。
+NTT和国内ISP互联时间很早,在2000年后,NTT和当时的网通互联,互联出口设在上海和北京,并在上海和北京分别建设NTT的PoP节点(少数国外ISP将PoP设在国内的案例)。
+值得一提的是,但是这是目前国内直连日本NTT延时很低且很稳定的渠道,CN2到日本NTT都干不过它,根据实测,目前NTT-9929的速度基本取决于用户接入的9929的带宽速度。
+中国电信163和日本NTT之间的扩容就勤快多了,电信还在日本东京设立了PoP方便和日本本土ISP快速互联。听起来很美好是吗?但是这不妨碍电信163和日本NTT之间日常大爆炸(里面大部分都是被巨量的DDOS流量打崩的)。
+可直连骨干网:AS4134、AS4837、AS58423
中国电信的163与IIJ的互联是通过电信在东京的PoP实现的,国内可以通过三大汇聚层轻松访问PoP节点。互联的网络质量远好于和NTT的质量。IIJ是电信163用户造访日本网站最好的线路之一,目前已经胜过软银,不考虑高峰丢包和延时抖动,是性价比之选。
+中国联通169与IIJ的互联方式和电信几乎一样,但是综合来看要好于163与IIJ互联的质量。提供IIJ接入的IDC价格比较亲民的很多,如果不愿意接受软银的高价位的话,那就上IIJ吧。
+目前移动和IIJ的互联已经通过东京移动的PoP来完成,故移动到日本IIJ不再绕香港而是通过NCP海缆直连东京的PoP后与IIJ完成互联,上海移动到东京IIJ参考延时为45ms(网上查的)。
+综上,IIJ是日本地区对我们比较友好的,也是价格相较于其他三家比较实惠的一家ISP,如果没有太小众化的需求,上国内走IIJ的VPS是很省心的选择。
+可直连骨干网:AS4134、AS4837、AS9929、AS58423
BBTEC(软银)其实是近几年才被我们注意到的一家ISP,在上海地区设有PoP并与电信163和联通169/9929互联。该线路一直被称之为联通到日本最好的线路之一。
+想要补充一点的是,9929早期和软银并没有直连Peer,而是借助4837(联通169)作为跳板实现的。而近期在路由测试中,我们可以清楚地看到软银和9929已经在上海PoP实现互联,但是在BGP ToolKit上都未显示2者有任何形式的互联,基本可以判断是Private Peer。
+电信163到软银延时相比于NTT属实较低,但是却同样跑不出什么速度来,延时最初是日本御四家里最低的,但是后来因为使用人数的增加,延时逐渐不如IIJ。
+联通169到软银的延时则相对不稳定,取决于去程走上海口和北京口,通常BBTEC回程经由自己的上海POP与联通互联。尽管联通和软银互联的优势已经不如以前,但是目前仍旧是联通到日本最好的线路之一。
+联通9929到软银的延时稳定,互联速度也取决于用户接入的9929带宽速度。
+如今,移动已经在日本的东京设立了PoP,所以从回程看,除了广州移动还是继续走香港CMI,其余均在日本就Peer,并由移动自己的骨干网负责流量回国承载。目前去程依旧全部绕香港CMI,这也导致北方移动延时的升高。总体来说,软银对北方移动不友好。
+常见运营商:NTT、Singtel、Telstra、StarHub、MyRepublic、PCCW(G)、Cogentco、HE、Tata、CMI、CUG、BGP.NET、SG.GS
+常见数据中心:SGIX、EIESG(Equinix Internet Exchange Singapore)
+下游:OVH、Cloudflare、Google、Amazon
+NTT(新加坡)
+可直连国内骨干网:AS4134、AS58453
+正如你所见,NTT在亚太地区无处不在~ 所以我们一般把NTT视作亚太地区ISP的标杆,这已经成为了事实上公认的标准。
+在新加坡,NTT也拥有巨量的骨干资源,轻松连接新加坡所有的本地ISP。NTT也有多条新加坡至日本的海底光缆所有权/使用权,所以NTT可以借新加坡作为跳板,以此连接马来西亚、菲律宾、印度尼西亚、泰国、越南、缅甸、柬埔寨、印度等国。
+中国电信163与2020年和NTT在新加坡正式建立互联,即意味着新加坡NTT从即日起无需绕行日本再与163骨干网互联,但是情况变得更加糟糕,因为新加坡地区的中国电信163和NTT互联宽带很小,所以几乎全天都处于被塞满的状态,延时异常偏高,丢包率极大,因此非常不推荐使用163连接新加坡地区的NTT。
+移动的CMI在新加坡有自己的PoP,同时在当地就可以和NTT互联,因互联宽带很大,所以目前没有看到被塞爆的情况,移动用户目前访问新加坡地区资源的主流渠道就是通过新加坡PoP。
+联通9929和联通169目前都不能直连新加坡NTT,请详见上面的日本NTT。
+常见运营商:KT、SKT、LG (绕路的ISP:NTT、PCCW、Telstra Global 绕日绕港绕新加坡 故不测试)
+常见数据中心:KINX
+常见下游:Moack、Oracle、Cloudflare、Amazon、Azure
+韩国本土网络发达,除了三大ISP以外还有地区性ISP,大陆地区前往韩国主要走TPE、APG、APCN-2、NCP四大海缆。
+国际路由差强人意,但靠着CDN也足够应付。但到中国大陆的带宽与路由不尽人意,绕路与直连汇聚层日常性堵塞层出不穷,丢包与抖动比较严重(虽然没有到163-NTT那么夸张)。
+同时韩国的互联网管理相对严格,购买上比较麻烦(建议别买,没啥必要)。
+可直连骨干网:AS4134、AS4809、AS4837、AS9929、AS58453
KT(Korea Telecom),韩国最大电信运营商,市场占有率排名第一。
+英雄联盟里KT战队的赞助商,就是他,你如果打LOL就对这个名字很眼熟.
+目前电信163/CN2和韩国KT之间的互联是通过APG海缆完成的,因为APG海缆只在上海有登陆,所以目前前往韩国KT都是走上海出口。
+电信163至韩国KT的速度在Peer不被塞满的情况下单线程能跑100-200Mbps,晚高峰受限于汇聚层和Peer宽带的双重因素影响,速度受限比较严重。CN2虽然不用太担心汇聚层的拥塞问题,但是目前的Peer宽带依旧是比较主要的速度和延时等稳定性制约因素。
+联通9929与KT有互联,同样也是走上海出口。高峰期几乎无丢包,延迟极低,单看极限最低延迟逼近沪韩IPLC;可惜经常抖动,虽然幅度非常小。速度方面也属于跟日本ISP到9929一样,KT到9929的速度取决于用户接入的9929带宽速度。
+可直连骨干网: AS4134、AS4837、AS9929
Deutsche Telekom AG ,德国电信,德国第一大ISP,T1级。旗下移动运营商T-mobile相比于DTAG更加知名。
+DTAG于AS4134和AS4837均有peer。同时也是AS9929上游。但延迟均200+起跳。
+电信163普通家宽会被强制丢包,而163plus能保证相对稳定延迟与相对较低的丢包
+联通169则取决于汇聚层是否拥塞。非拥塞状态则能保证网络质量。但是只限于北方地区的联通。
+南方地区的联通将会被无慈悲的绕美。
+AS9929依旧稳定发挥,甚至延迟优于AS4134 AS4837,但速度很勉强,几乎稳定80Mbps。
+可直连骨干网:AS4134、AS4837、AS9929、AS58453。
Cogentco由于在Traceroute上的细节写的过于清楚明白,以至于有一部分以为跳数越多越差人觉得Cogentco不行。虽然它也确实不太行…
+Cogentco,联通9929真正的互联主力……几乎绝大部分的欧美线路到9929都会被Cogentco宣告。以至于在欧洲会出现回程不走DTAG硬是跑Cogentco
+外加联通9929的NOC基本不会主动调整欧美路由。速度十分玄学,单线程在50Mbps摇摆,多线程却接近跑满。
+洛杉矶和圣何塞是美西重要的面向亚太地区的互联网PoP中心,TPE海缆多从此处2点接入。中美之间的互联占据了出境流量很大的一部分,也是电信163出国的主要路径。
+可直连骨干网:AS4134、AS4837、AS58453
HE,全称为 Hurricane Electric(飓风电气),目前是坐拥全球以Peer数量计算的最大IPv6骨干网的ISP,骨干网自治编号为AS6939。HE也提供免费的IPv6 Tunnel,以方便IPv4单栈的用户能够无障碍地访问IPv6网络。
+我们看到的亚太地区(香港、新加坡)的低价VPS产品线,几乎都一致地选择了HE作为唯一的互联网接入,而且接入的宽带并不大,平均1Gbps。但是哪怕是HE这样的ISP,在亚太地区的BGP Transit也颇为昂贵,这些商家为了能够有所盈利,在超低的VPS价格上,宽带上面必须大幅超售。
+电信163和HE在洛杉矶有10~20G的互联,平时鲜有出现较大的延时抖动,但是速度限制较为严重。
+联通169和HE的洛杉矶互联通常被视为在廉价互联里面很具有性价比的,相比于联通169和GTT的互联,和HE的互联质量就要好很多,很多用户也在尽可能选择更价廉物美的选择。
+CMI与美西的互联一向较差,并不具有较好的连通性,再加上HE和CMI的互联本身就炸的比较厉害,所以CMI就拉倒吧。
+可直连骨干网:AS4134、AS4837、AS58453
GTT,前身为Global Telecom and Technology,自1998年成立以来,在跨国电信业务上耕作至今。
+联通169在美西较大地依赖GTT的互联,导致延时相比正常美西延时高很多,速度并不乐观。
+电信163和GTT的互联却是出乎意料的好,根据SmokePing的结果,电信163和GTT的互联全天几乎不丢包,完全受限于汇聚层是否通畅。这就意味着只要使用高Qos的电信宽带就可以获得较好的速度。
+可直连骨干网:AS4134、AS4809、AS4837、AS58453
Telia是瑞典最大的电话和电信通讯公司,前身为瑞典电报局及芬兰电讯。现更名为Arelion,但目前在路由上的名称依旧是Telia。
+Telia在美国、欧洲都有和电信163互联,总体来说是很中规中矩的线路。
+可直连骨干网:AS4134、AS4837、AS9929、AS58453
跟欧洲情况差不多。
+电信163在美西较大程度上依赖Cogentco的互联,天天爆炸。
+可直连骨干网:AS9929
联通9929与Verizon的互联一言难尽,延迟不是最优,单线程速度也不是最优。高峰期单线程速度在50-70Mbps震荡。而多线程速度倒是能跑满,非常的玄学。
+有时候其他北美ISP到联通9929需要经Verizon转发,而被转发的速度就很难保证了。
+需要注意的是,欧洲/北美的网络情况跟亚太差异比较大。欧美的中小ISP大部分依靠的是IX互联或者机房托管的混合网络接入。虽然商业网络的价格比亚洲地区便宜,但至少对中国用户来说,很少再回程路由中遇见欧美的Regional T1或者高质量T1 ISP。
+Done.
+ +前言 SSH(Secure Shell 的缩写)是一种网络协议,用于加密两台计算机之间的通信,并且支持各种身份验证机制。
+1995年,芬兰赫尔辛基工业大学的研究员 Tatu Ylönen 设计了 SSH 协议的第一个版本(现称为 SSH 1),同时写出了第一个实现(称为 SSH1)。
当时,他所在的大学网络一直发生密码嗅探攻击,他不得不为服务器设计一个更安全的登录方式。写完以后,他就把这个工具公开了,允许其他人免费使用。
+SSH 可以替换 rlogin、TELNET、FTP 和 rsh 这些不安全的协议,所以大受欢迎,用户快速增长,1995年底已经发展到五十个国家的20,000个用户。SSH 1 协议也变成 IETF 的标准文档。
+1995年12月,由于客服需求越来越大,TatuYlönen就成立了一家公司SCS,专门销售和开发SSH。这个软件的后续版本,逐渐从免费软件变成了专有的商业软件。
SSH 1 协议存在一些安全漏洞,所以1996年又提出了 SSH 2 协议(或者称为 SSH 2.0)。这个协议与1.0版不兼容,在1997年进行了标准化,1998年推出了软件实现 SSH2。但是,官方的 SSH2 软件是一个专有软件,不能免费使用,而且 SSH1的有些功能也没有提供。
1999年,OpenBSD 的开发人员决定写一个SSH 2 协议的开源实现 ,这就是 OpenSSH 项目。该项目最初是基于 SSH 1.2.12 版本,那是当时 SSH1 最后一个开源版本。但是,OpenSSH 很快就完全摆脱了原始的官方代码,在许多开发者的参与下,按照自己的路线发展。OpenSSH 随 OpenBSD 2.6 版本一起提供,以后又移植到其他操作系统,成为最流行的 SSH 实现。目前,Linux 的所有发行版几乎都自带 OpenSSH。
李华是一个大学生,现在他买了一台服务器,公网IPv4为114.514.114.514,李华打算连到上面看看:
+ssh -p 22 root@114.514.114.514
+
+随后命令行弹出了密码输入,李华输入了初始密码114514,成功登录了进去;现在每次登录只要输入一行命令就可以,大功告成!
+一段时间后,李华的linux知识提高了不少,他发现有不少IP在用随机密码不断尝试登录自己的服务器!这太危险了!
+于是,李华查阅了资料,发现有一篇博客乱七八糟:服务器初始化与安全设置,于是他将openssh-server的端口改成了2333,并开启了fail2ban,这下应该安全了!
+### 更换SSH端口
+
+使用root账户或已经有sudo权限的用户登录到系统。
+
+打开SSH配置文件`sshd_config`,可以使用文本编辑器如nano或vi。以下是使用nano编辑器的示例:
+
+sudo vim /etc/ssh/sshd_config
+
+在配置文件中找到以下行:
+
+Port 22
+
+这是SSH默认的端口号,你可以将其更改为你想要的任何未被占用的端口号。例如,将端口更改为2333:
+
+Port 2333
+
+保存并关闭文本编辑器。重新启动SSH服务,以应用更改:
+
+sudo service ssh restart
+
+或者,如果你的系统使用systemd,可以使用以下命令:
+
+sudo systemctl restart ssh
+
+### 安装 Fail2ban
+
+sudo apt-get install fail2ban
+
+#### Debian 12 及以上的版本需要手动安装 rsyslog
+
+sudo apt-get install rsyslog
+
+####启动 Fail2ban 服务
+
+sudo systemctl start fail2ban
+
+#### 开机自启动
+
+sudo systemctl enable fail2ban
+
+#### 查看 Fail2ban 服务状态
+
+sudo systemctl status fail2ban
+
+
+但是服务器依然在被爆破,李华又又研究了以下教程,决定将自己的服务器由密码登录改为密钥登录,这下没有牛马来爆破了!
+#### 执行以下命令生成.pub后缀的公钥和无后缀的密钥:
+
+ssh-keygen
+
+注意不同密钥对名称不能相同;同时可以为这两个文件用密码加密;
+
+#### 随后将.pub后缀的公钥中的内容写入服务器的~/.ssh/authorized_keys中;
+
+#### 使用以下命令编译服务器的SSH配置:
+
+vim /etc/ssh/sshd_config
+
+将其中的该行改为PasswordAuthentication no,保存退出;随后使用
+
+sudo systemctl restart sshd
+
+重启SSH即可禁用密码登录;
+
+#### 将PermitRootLogin一栏改为PermitRootLogin prohibit-password**,即可实现仅root用户密钥登录;
+
+#### 使用以下命令查看输出,
+
+sudo cat /etc/ssh/sshd_config | grep -E 'PasswordAuthentication|PubkeyAuthentication'
+
+如有PasswordAuthentication no → 禁用密码登录以及PubkeyAuthentication yes → 允许密钥登录则成功。
+
+> 注意authorized_keys**的权限为600,如果不是则需要改正:chmod 600 ~/.ssh/authorized_keys
+
+现在服务器安全了,但随着服务器数量的增加,李华很快发现一个新问题,如何管理这些个SSH连接呢?手动输入太慢了,每次都要复制粘贴也很麻烦,但是又不得不用,总不能回退到密码时代吧?况且数量多了,密码也记不住。
+于是李华运用软件工程学的思想,想着,这种大众的需求应该有人解决过了吧?果然,李华很快在GitHub上找到了一个开源跨平台的SSH管理软件,electerm!
+
通过在electerm的书签中写入服务器的地址,登录用户和密钥,只要打开electerm并点击书签就可以连接了,太方便了!
+随着技术阅历的增长,李华看electerm越来越不顺眼:用它管理SSH固然方便,但同时这就得在各个系统上安装一个Electron架构的软件,而且用electerm的shell并不好用,并且备份electerm的配置不能给其他软件使用。终于,在一次界面崩溃之后李华忍无可忍,决定更换新的方案!
+通过研究,李华发现原来openssh有自带的管理方法,且非常便捷好用。
+首先,李华在用户目录下创建了一个.ssh文件夹,linux中在/home/username/.ssh这里,windows下在C:\Users\username\.ssh这里。
随后,李华安装了openssh在系统上,linux中一般已经存在,windows上在设置-系统-可选功能-添加功能中选中OpenSSH Client和openssh-server开启即可.
随后,李华在.ssh文件夹下创建了一个文件,名为config,并在其中写入以下内容:
Host US
+ HostName 114.514.114.514
+ User root
+ IdentityFile ~/.ssh/US
+ IdentitiesOnly yes
+
+随后李华在对应的位置~/.ssh/US创建了一个文件,李华将服务器的私钥放了进去,里面是以-----BEGIN OPENSSH PRIVATE KEY-----开头-----END OPENSSH PRIVATE KEY-----结尾的私钥。
现在,要登录114.514.114.514这台服务器,只需要使用ssh US命令就可以连上服务器了,不用再手动输入了!
在进一步了解SSH之后,李华很快又发现了新的问题,服务器的私钥放在本地是不安全的!尤其是Windows这种安装源松散,鱼龙混杂的系统上。究竟有没有更好的方法呢?在对keepassxc进行研究后,李华终于得出了一个几乎完美的方案!
+这样一来,当你执行ssh xxx时,ssh 不是去读私钥文件,而是通过SSH_AUTH_SOCK环境变量找到 KeePassXC 的 agent。KeePassXC 会提示你解锁数据库/确认使用密钥。私钥不会离开 KeePassXC,只是 KeePassXC 用私钥做一次签名,把结果返回给 ssh。这样,硬盘上不需要保存私钥文件,安全性更高,且只需要备份.ssh文件夹和keepassxc的kbdx文件即可.
那么该怎么做呢?
+首先,将.ssh文件夹中的config进行修改,把私钥文件改为公钥文件,同时创建对应的~/.ssh/US.pub公钥文件,里面是以ssh-ed25519或者ssh-rsa开头的公钥.
Host US
+ HostName 114.514.114.514
+ User root
+ IdentityFile ~/.ssh/US.pub
+ IdentitiesOnly yes
+
+随后在keepassxc的设置-ssh代理中开启启用SSH代理集成.(openssh)
接下来在keepassxc中左侧栏新建一个文件夹,名为SSH,里面新建条目,标题为US(和config中一致),然后在右侧高级中新建附件,文件名为US(和config中保持一致),文件内容为US的私钥.随后在左侧SSH代理中选中在打开或解锁数据库的时候,向代理添加密钥和数据库锁定或关闭时,从SSH代理中删除密钥这两个选项,并将下面的私钥选择附件,即为我们刚刚在高级中新建的US,可以看到对应的公钥也出现了,上一步没有公钥的可以在这里添加.按确定后关闭keepassxc并重新开启,这时候就可以使用ssh US命令登录了!
++注意每次登录前先开启keepassxc并解锁!
+
Done.
+ +前言 什么是SSL/TLS证书?它有什么作用?如何部署?
+SSL 的全称是 Secure Sockets Layer(安全套接字层),而 TLS 的全称是 Transport Layer Security(传输层安全协议)。最初由 Netscape 开发的 SSL 协议用于保护网络通信,但由于其存在的安全漏洞,后来被更新、更安全的 TLS 协议所取代。
如今,当我们谈论“SSL 证书”时,实际上指的是支持 TLS 协议的数字证书,两者在功能上没有本质区别,只是在命名上沿用了历史传统。该证书是由受信任的数字证书颁发机构 CA,在验证服务器身份后颁发,且具有服务器身份验证和数据传输加密功能。简单来说就是HTTP+SSL/TLS证书=HTTPS.
++使用公钥加密的数据只能用对应的私钥解密,使用私钥加密(签名)的数据可以用对应的公钥验证。
+
++客户端和服务器都支持非常多的密码套件,比如“ECDHE-RSA-AES256-GCM-SHA384”。格式是“密钥交换算法 + 签名算法 + 对称加密算法 + 摘要算法”,这个密码套件的意思就是:“握手时使用 ECDHE 算法进行密钥交换,用 RSA 签名和身份认证,握手后的通信使用 AES 对称算法,密钥长度 256 位,分组模式是 GCM,摘要算法 SHA384 用于消息认证和产生随机数。”
+
可以看到,验证证书的有效性需要通过CA证书,由CA机构(如DigiCert +Let's Encrypt)等颁布,CA证书的层级结构如下:
+操作系统和浏览器内置了受信任的根CA证书列表,当验证网站证书时,系统会沿着证书链向上追溯至根CA;如果能找到一个受信任的根CA,且证书链上所有签名有效,则验证通过.这就是保护我们上网安全的信任链的基础。
当我们访问网页时,往往会看到左上角的锁图标,里面是Google Trust Services或者DigiCert Inc等等,代表证书的颁发来源。如果锁提示不安全,可能是证书过期或者找不到CA证书,即有可能是自签名证书。什么是自签名证书?
我们先来看证书颁发的流程。
+可以看到过程有点麻烦,个人建站的话往往使用自签名证书,即ssh-keygen生成的公钥和私钥,由于没有CA所以会显示不安全。
sslforfree由 ZeroSSL 支持颁发的免费SSL证书.
+通过AMH提供的自助在线申请服务申请SSL通配符证书.需要注册AMH账号.
+letsencrypt,支持申请多渠道SSL证书.
+借助Punchsalad提供的在线服务申请SSL证书,无需登录,仅需邮箱即可完成SSL通配符证书申请和签发.
+以下是三种主要SSL证书验证类型的对比:
+| 特性 | 域名型SSL (DV SSL) | 企业型SSL (OV SSL) | 增强型SSL (EV SSL) |
|---|---|---|---|
| 验证级别 | 最低 | 中等 | 最高 |
| 验证内容 | 仅验证域名所有权 | 验证域名所有权和组织信息 | 最严格的验证,包括法律、物理和运营存在的全面验证 |
| 验证流程 | 自动化验证(邮件、DNS记录等) | 半自动验证 | 人工审核为主 |
| 签发时间 | 几分钟到数小时 | 1-3个工作日 | 5-7个工作日 |
| 浏览器显示 | 普通锁图标 | 普通锁图标 | 地址栏绿色显示(部分浏览器已取消) |
| 适用场景 | 个人博客、信息网站 | 企业网站、电子商务 | 银行、金融机构、大型电商 |
| 成本 | 低 | 中等 | 高 |
| 信任度 | 基本 | 中等 | 最高 |
| 证书信息 | 只包含域名信息 | 包含组织名称和域名 | 包含完整的组织详细信息 |
| 安全加密强度 | 相同 | 相同 | 相同 |
有时候可以购买如*.xxx.com的通配符证书,即一个证书通用与所有子域名。以及还有其他如多域名证书和上面提到的DV/OV/EV证书的类型。
| 证书类型 | 覆盖范围 | 安全级别 | 验证过程 | 适用场景 | 价格范围 |
|---|---|---|---|---|---|
| 单域名证书 | 仅一个特定域名 | 基本到高 | DV/OV/EV | 个人网站或小型企业 | 低到高 |
| 通配符证书 | 主域名及其所有一级子域名 | 基本到中等 | DV/OV | 拥有多个子域名的网站 | 中等到高 |
| 多域名证书(SAN) | 多个不同域名 | 基本到高 | DV/OV/EV | 管理多个不相关域名的企业 | 中等到高 |
| 自签名证书 | 任意 | 低 | 无需验证 | 测试环境、内部网络 | 免费 |
Done.
+ +前言 yt-dlp是一款功能强大的命令行工具,专注于下载视频与音频内容,支持数千个平台,是开源下载工具爱好者的常用选择。
+ +有时候我们想要下载网络上的某些视频,比如Bilibili,YouTube等等,但它们没有提供下载按钮,这时候就可以用开源的yt-dlp来进行下载。和Aria2一样,很多下载软件的核心就是yt-dlp.
+起源与演进
+youtube-dl 由 Ricardo García González 于 2006 年创建,最初仅支持 YouTube,随后扩展至其他网站,成为 GitHub 上最受欢迎的开源下载项目之一.项目维护者在 2011 年、2021 年等阶段陆续交替,由 phihag、dstftw 等接手.2020 年,唱片业协会(RIAA)发起 DMCA 要求删除该项目,虽一度被移除,但在公众与 EFF 的推动下于当年 11 月恢复,并促使 GitHub 改进相关策略.
停滞,youtube-dlc → yt-dlp 的诞生
+随着开发进度放缓,社区于 2020 年衍生出 youtube-dlc 分支,在2021 年演变为更活跃的 yt-dlp 项目,它继承了 youtube-dl 的核心功能,并引入更多改进,包括更好的格式选择、多线程下载等,成为了GitHub上star最多的项目之一.
重构与功能拓展
+yt-dlp 从 youtube-dlc 完全重构,新增许多 extractor(解析器)、改进配置与默认行为,还扩展了插件系统和兼容性支持.
从yt-dlp官方GitHub上下载exe二进制文件:
+ +将其放到一个目录下,比如C:\Users\<你的用户名>\yt-dlp\yt-dlp.exe,随后添加环境变量。
++添加环境变量:Win键搜索“环境变量”,打开“编辑系统环境变量”,点击最下方的“环境变量”,选择“系统变量”中的path,点击“编辑”,新建一个变量,将上面的目录 C:\Users<你的用户名>\yt-dlp\ 写入,注意去掉前后引号,随后确定-确定-确定退出。
+
更新版本:
+yt-dlp -U
+
+python3 -m pip install -U yt-dlp
+
+sudo apt install yt-dlpsudo pacman -S yt-dlpsudo dnf install yt-dlp{pkgs, ...}: {
+ home.packages = with pkgs; [
+ peazip
+ ];
+}
+
+pkg update && pkg upgrade
+pkg install python libexpat openssl ffmpeg
+python3 -m pip install -U yt-dlp
+
+yt-dlp "https://www.bilibili.com/video/BVxxxxx" --write-subs --embed-subs --sub-langs all,-live_chat
+
+--write-subs: 将字幕文件下载为单独文件 (如 .vtt 或 .ass)
+
+--embed-subs: 将下载的字幕嵌入到视频文件中(如果格式支持)
+
+--sub-langs all,-live_chat: 下载所有字幕语言,但排除像“弹幕/实时聊天”之类的非标准字幕流
+
+先使用这个命令查看可用格式:
+yt-dlp -F https://www.youtube.com/watch?v=xxxxxxxxxxxx
+
+然后它会列举出所有可用的格式,如下:
+[youtube] MgtOAVOXBWo: Downloading webpage
+[youtube] MgtOAVOXBWo: Downloading tv client config
+[youtube] MgtOAVOXBWo: Downloading tv player API JSON
+[youtube] MgtOAVOXBWo: Downloading ios player API JSON
+[youtube] MgtOAVOXBWo: Downloading m3u8 information
+[info] Available formats for MgtOAVOXBWo:
+ID EXT RESOLUTION FPS │ FILESIZE TBR PROTO │ VCODEC VBR ACODEC MORE INFO
+──────────────────────────────────────────────────────────────────────────────────────────────────────────
+sb2 mhtml 48x27 0 │ mhtml │ images storyboard
+sb1 mhtml 80x45 0 │ mhtml │ images storyboard
+sb0 mhtml 160x90 0 │ mhtml │ images storyboard
+233 mp4 audio only │ m3u8 │ audio only unknown Untested, Default, low
+234 mp4 audio only │ m3u8 │ audio only unknown Untested, Default, high
+602 mp4 256x144 15 │ ~ 9.23MiB 81k m3u8 │ vp09.00.10.08 81k video only Untested
+269 mp4 256x144 30 │ ~ 14.94MiB 130k m3u8 │ avc1.4D400C 130k video only Untested
+603 mp4 256x144 30 │ ~ 15.90MiB 139k m3u8 │ vp09.00.11.08 139k video only Untested
+229 mp4 426x240 30 │ ~ 33.33MiB 291k m3u8 │ avc1.4D4015 291k video only Untested
+604 mp4 426x240 30 │ ~ 25.82MiB 225k m3u8 │ vp09.00.20.08 225k video only Untested
+230 mp4 640x360 30 │ ~ 73.50MiB 642k m3u8 │ avc1.4D401E 642k video only Untested
+605 mp4 640x360 30 │ ~ 55.73MiB 487k m3u8 │ vp09.00.21.08 487k video only Untested
+231 mp4 854x480 30 │ ~104.35MiB 911k m3u8 │ avc1.4D401F 911k video only Untested
+606 mp4 854x480 30 │ ~ 94.79MiB 827k m3u8 │ vp09.00.30.08 827k video only Untested
+311 mp4 1280x720 60 │ ~330.73MiB 2887k m3u8 │ avc1.4D4020 2887k video only Untested
+612 mp4 1280x720 60 │ ~197.04MiB 1720k m3u8 │ vp09.00.40.08 1720k video only Untested
+312 mp4 1920x1080 60 │ ~486.64MiB 4248k m3u8 │ avc1.64002A 4248k video only Untested
+617 mp4 1920x1080 60 │ ~369.06MiB 3222k m3u8 │ vp09.00.41.08 3222k video only Untested
+623 mp4 2560x1440 60 │ ~ 1.00GiB 8945k m3u8 │ vp09.00.50.08 8945k video only Untested
+
+我们下载312和233,即视频和音频,使用以下命令:
+yt-dlp -f "312+233" -o "<新视频的名字,要短一点>.%(ext)s" https://www.youtube.com/watch?v=xxxxxxxxxxxx
+
+这行命令会自动将下载的312的1080p/H.264的视频和233的音频合并为一个mp4视频,注意新的名称不能太长,否则会下载失败。
+如果要下载带字幕的视频,则使用
+yt-dlp -f "312+233" --write-subs --write-auto-subs --embed-subs --sub-langs "zh.*,en.*" -o "<新视频的名字,要短一点>.%(ext)s" https://www.youtube.com/watch?v=xxxxxxxxxxx
+
+这个命令会:
+下载1080p视频
+下载中文和英文字幕(包括自动生成的)
+将字幕嵌入到视频文件中
+同时保存单独的字幕文件
+参数说明
+--write-subs: 下载手动字幕
+--write-auto-subs: 下载自动生成的字幕
+--embed-subs: 将字幕嵌入到视频中
+--sub-langs "zh.*": 指定下载中文字幕(所有中文变体)
+--sub-format srt: 指定字幕格式(可选)
+
+下载视频:
+yt-dlp "视频链接"
+
+提取为 MP3 音频:
+yt-dlp -x --audio-format mp3 "视频链接"
+
+下载播放列表:
+yt-dlp -i "播放列表链接"
+
+批量处理(文件或多个 URL):
+yt-dlp -a urls.txt
+
+选择格式下载:
+yt-dlp -F "视频链接" # 显示所有格式
+yt-dlp -f 137+140 "链接" # 下载指定视频 + 音频合并
+
+自定义输出路径与模板:
+yt-dlp -o '%(title)s by %(uploader)s on %(upload_date)s.%(ext)s'
+
+日期过滤:
+yt-dlp --dateafter 20230101 --datebefore 20231231 "链接"
+
+速度限制 / 恢复下载 / 年龄筛选:
+-r 500K # 限速
+-c # 断点续传
+--age-limit 18 # 仅下载适合年龄 ≥18 的视频
+
+只输出描述,不下载内容:
+yt-dlp --skip-download "链接"
+
+下载封面、字幕、缩略图、元数据等:
+--write-thumbnail --write-sub --embed-subs --embed-thumbnail
+
+使用浏览器 Cookies 下载私密内容:
+--cookies your-cookies.txt
+--cookies-from-browser firefox
+
+并行下载示例(Hacker News 用户提供):
+yt-dlp --flat-playlist --print id playlist_url | \
+ parallel yt-dlp -x --wait-for-video 3 --download-archive archive.txt https://www.youtube.com/watch?v={}
+
+记录下载历史:
+yt-dlp --download-archive archive.txt "链接"
+
+配置文件设定默认参数:
+在 ~/.config/yt-dlp/config 文件中添加习惯参数,如下载路径、格式偏好等。
Done.
+ +Click here to be redirected.
diff --git a/public/page/10/index.html b/public/page/10/index.html new file mode 100644 index 0000000..26080c5 --- /dev/null +++ b/public/page/10/index.html @@ -0,0 +1,304 @@ + + + + +前言 openwrt 是一个自由的、兼容性好的嵌入式 linux 发行版。作为软路由玩家必备的一款神器,可以实现诸如去广告,多拨和科学上网等多种功能。本文介绍openwrt在各种平台上的部署流程。
+前言 假期将至,不少家里有闲置设备的小伙伴想尝试开设一个我的世界(Minecraft)服务器,却不知从何下手。本文以 PVE-Debian-MCSM 为主线介绍其部署流程。
+前言 linux搭建安卓虚拟机有Waydroid,QEMU和Docker三种方案,各有不同。
+前言 本文基于常见发行版(systemd + NetworkManager + PipeWire/ PulseAudio / ALSA),目标是把常见的桌面/笔记本硬件(Wi-Fi、蓝牙、亮度、音量)通过命令行可复现、可理解地组织起来。
+前言 本文面向刚刚从Windows转向Linux的一般使用者和想在Linux上进行开发的开发者,主要说明其系统特点和使用须知。
+前言 LazyVim 是一个基于 Neovim 的现代化配置框架,易于定制和扩展,这里对其介绍并说明使用方法。
+前言 Aria2是一款开源、跨平台的命令行界面下载管理器,常常被各种下载器软件使用。
+前言 yt-dlp是一款功能强大的命令行工具,专注于下载视频与音频内容,支持数千个平台,是开源下载工具爱好者的常用选择。
+前言 下载,就是将我们所需要的文件数据,通过网络从拥有该文件资源的计算机上传输过来并保存到我们的计算机上,供我们使用。本系列将详细讲述各种常见网络下载技术的原理,包括HTTP,FTP,BT等等。
+前言 本文为 Markdown 教程,内容涵盖 Markdown 的历史、作用、基本语法和显示效果,可以在github将本文的源码拷贝供大家参考和学习。
+前言 最近nekoray项目归档,考量新的singbox前端时发现这个项目不错,不过在Arch linux中运行有一些小问题,这里做个总结。
+前言 FRP (Fast Reverse Proxy) 是一个用Go语言开发的高性能反向代理应用,可以帮助您轻松地进行内网穿透,对外提供服务.
+前言 Ventoy 是一款开源免费的多系统启动盘制作工具,这里说明其主要功能的制作流程。
+前言 本文介绍常用的家庭网络测试方法,包括开源固件和闭源商用设备的测试。
+前言 本文记录常用虚拟化平台的使用与操作,包括Vmware,Hypr-v,QEMU等等。
+前言 Docker的出现极大简化了建站流程,较过去的LAMP方式优雅了许多,配合Nginx反向代理可以快速上线HTTPS站点。
+前言 CSdiy珠玉在前,为CS教育做出了极大贡献.这里分享一些优质的CS学习相关视频.
+前言 由于 Windows 中开发环境较 linux 复杂,这里总结 Windows 中使用 Jupyter 开发 Python 的环境配置。
+前言 由于 Windows 中开发环境较 linux 复杂,这里总结 Windows 中使用 VScode 开发 C/C++ 的环境配置。
+前言 由于厂商默认安装windows家庭版导致各种问题频发,这里作者封装了一个开箱即用的,全自动安装,激活和优化的Windows11镜像。
+前言 Windows的正版售价十分昂贵,2025年的今天大部分人都使用着OEM厂商自带的windows系统或自己想办法激活,那么,激活到底是什么原理?
+前言 Windows操作系统作为全球最为普及的桌面操作系统之一,其用户界面的设计非常经典,但存在许多不足之处,本篇记录一些常用脚本。
+前言 由于厂商默认安装windows家庭版导致各种问题频发,这里对 widnows 安装做一个总结,以及附上我个人的windows配置。
+前言 在日常使用浏览器时,掌握一些快捷键和技巧可以节省大量时间,提高工作和学习效率。通过学习和实践,能够更加轻松地应对各种网页浏览场景,让浏览器成为工作和学习的得力助手。
+前言 讲起播客,许多人第一反应是喜马拉雅,但其实播客的订阅和收听有许多种方式。本文带你了解订阅播客的各种方式,并告诉你市面上有哪些不错的播客客户端可供选择。
+前言 RSS 提供了一种数据格式,以 XML(可扩展标记语言)的形式组织信息,包括文章标题、摘要、链接和发布日期等。这些信息形成了所谓的“订阅源”(Feed),用户可以使用RSS阅读器(Feed Reader)来订阅这些源。
+前言 本文旨在介绍开源以及开源许可证,这些许可证规定了使用、修改和分发开源软件的条件。通过了解不同类型的开源许可证及其特点,读者将能够更好地理解在开发和使用开源软件时的法律和道德责任。
+前言 poste.io 邮件服务基于 Docker 搭建,用的是 Haraka + Dovecot + SQLite 邮件系统,占用资源较少,安装简单,适合个人使用。
+前言 在互联网的日常使用中,电子邮件作为一项基础服务扮演着重要的角色。尽管在过去几十年里出现了各种新型的通讯方式,但电子邮件仍然保持着其不可替代的地位。了解电子邮件的工作原理,有助于更好地理解这一基础服务是如何运作的。
+前言 内容分发网络(CDN)是一组分布在不同地理位置的服务器网络,使用户能够就近获取内容,从而降低延迟并缓解源站压力.
+前言 本文主要探讨的是IPv4网络,国际出口线路的质量分析以及各大ISP的介绍。
+前言 Git,作为现代软件开发中不可或缺的版本控制工具,常常让初学者感到困惑。本文旨在介绍 Git 的全流程安装和基本使用,希望能够帮助新手更轻松地理解和掌握 Git 的基本概念和操作。
+前言 在从前的机械硬盘时代,由于硬盘空间小,且没有时常清理垃圾文件,常常导致硬盘空间严重不足;特别是在以 Windows 平台为代表的 C/D盘 体系下。那么,我们常说的垃圾清理,释放硬盘空间,到底是在清理什么?哪些文件可以被清理?
+前言 个人博客的搭建具有许多的方案可以选择,本文介绍如何快速部署一个博客,并将其发布到公网。
+前言 机械革命作为一款极高性价比的笔记本,其优惠的力度和问题不断的故障让玩家们爱恨交织;作者在其上安装 Linux 时遇到了键盘失灵的问题,为了避免更多人踩坑,故写本文。
+前言 中文和英语发音习惯不同,容易引起误解。本文旨在帮助您准确发音常见的科技术语,欢迎随时补充。
+前言 由于临近升学,校园网不尽人意,因此许多小伙伴有了买一张流量卡的计划。本文以三大运营商为例,说明常见流量卡的套路与选择。
+前言 Arch linux是一个轻量、灵活、滚动更新的 Linux 发行版,衍生了诸多优秀的桌面端linux。其官方Wiki更是被称为技术界的“武林秘籍”;这里介绍其安装与使用。
+前言 由于 AppleTV 的高昂的售价和普通电视盒子广告的泛滥,一台开源、多功能的原生安卓电视盒子逐渐成为智能家居的必备神器。出于对 IPTV、YouTube 和家庭影院等需求,以及对一面赏心悦目电视墙的期待,这里分享 Android TV (以下简称ATV)安装的一些要点。
+前言 自安卓系统诞生以来,root 一直是玩机的必备过程。时至今日,在安卓定制系统日益完善的情况下,能 root 的机型越来越少,本文以小米手机为例,介绍 root 的具体方法。
+${i(30)}
+${i(40)}
+
+
+ This is the Atom news feed for the
+
It is meant for news readers, not humans. Please copy-and-paste the URL into your news reader!
+
+
+
Powered by Feed.Style
+ + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.PS:因为昨天输入法突发恶疾,所以无法按时更新。
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,这周三提前一天更新.
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,暂定每周四进行更新.
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,暂定每周四进行更新.
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,暂定每周四进行更新.
+据广告拦截软件 SponsorBlock 开发者发布的消息,YouTube 正在测试直接将广告从服务端注入到视频中。
这种技术对服务端的基础设施要求应该是非常高的,因为 YouTube 仍然需要考虑个性化广告,即每次需要将针对特定用户感兴趣的广告注入到视频流的特定位置。当然用户观看界面也需要做一些改变,因为进入广告片段后还需要提供能够给用户点击链接的交互选项,避免广告确实被用户看了,但感兴趣的用户没法直接点击广告内容。
那么有办法能够继续屏蔽这种视频流广告吗?应该是有的,SponsorBlock 认为既然 YouTube 需要在前端界面提供可点击的链接,那就必然需要加载某段代码用来标记广告频段出现的时刻,如果能检测到视频流中的广告时刻,那么进行针对化的操作也可以跳过广告,最简单的方式就直接快进这部分。
SJTUG(上海交通大学 Linux 用户组)6月6日发布公告:
+++非常遗憾,接上级通知,即时起我们将中止对 dockerhub 仓库的镜像。docker 相关工具默认会自动处理失效镜像的回退,如果对官方源有访问困难问题,建议尝试使用其他仍在服务的镜像源。我们对给您带来的不便表示歉意,感谢您的理解与支持。
+
原公告"接上级通知","因监管要求"等字眼,现在已经被删除。随后,中科大及多家其他镜像站也接连停止服务。
+据称,是有人上传了关于涉政人物的AI语音合成器的docker镜像。
随后发现原来去年就有了一个 "AtomHub 可信镜像中心",由开放原子开源基金会主导,华为、浪潮、DaoCloud 、谐云、青云、飓风引擎以及 OpenSDV 开源联盟、openEuler 社区、OpenCloudOS 社区等成员单位共同建设。
V2EX上的讨论:如何评价新一代的国产可信 Docker 镜像中心 Atomhub
+如果你的windows没有关闭自动更新,那么会被捆绑安装微软电脑管家。该软件提供多种语言,不过现阶段只在中国市场进行推送安装。理论上只要是系统区域设置为中国的设备接下来都会自动安装微软电脑管家,不需要经过用户的任何点击。
目前可以在设置中卸载微软电脑管家,但继续安装后续的更新就不知道微软是否还会继续给用户捆绑安装。
据反馈不少人对其持中立态度,因为该软件空间占用非常小且功能实用,不过笔者一向对这些管家类软件抱警惕态度。
从 2024 年 6 月 3 日起在 Chrome Dev、Canary 和 Beta 渠道,如果用户仍然安装有 Manifest V2 扩展,那么用户访问扩展管理页面 chrome://extensions 时会显示警告信息,通知他们 Manifest V2 扩展将很快不予支持。。短时间内禁用的 Manifest V2 扩展可以重新启用,但未来将会被彻底禁用。
Manifest V3 受争议之处是它限制了 WebRequest API 的功能,用 declarativeNetRequest 替代了 WebRequest。广告屏蔽扩展如 uBlock Origin 会受到影响,因为它们使用 WebRequest 在广告下载前屏蔽其请求。禁用 Manifest V2 扩展意味着 uBlock Origin 会被禁用。
开发者已经释出了使用 Manifest V3 的精简版本 uBO Lite,其功能弱于原版。原版未来只能在 Firefox 等浏览器上使用。
++PS:利好Firefox系浏览器
+
最近NAS赛道又被卷的火热,由于行业龙头群晖价格偏高,这几年国产 NAS 也是百花齐放,联想、架那极空间、海康威视、绿联等等纷纷入场。
5月23号绿联也是发布了自己最新的NAS系列产品,宣发力度非常大,吸引了很多用户购买。但用户使用的过程中发现了很多问题,比如 CPU 温度过高,相册备份失败,甚至 App 账号注册登陆流程都没法顺利进行等等。
最让人绷不住的是使用手册上竟然直接出现了友商“群晖”的字样。
6月3日晚上绿联被喷的把新 NAS 京东天猫全部下架,并发布了致歉信。
+结合这个时间点,可以合理推测可能是领导层为了赶 618 活动,导致开发不得不硬着头带 BUG 上线。
小米的米柚自 MIUI 9+ (Based on Android 7+ \ SDK 27+) 在安装未知应用(侧载安装未在应用商店商家认证的应用)时,引入了安装应用未知来源需要 SIM 卡的限制;安装未知应用权限,每张SIM卡拥有一定次数的限制,超限后无法申请该权限。
++微博网友:那我要是不插卡呢?给不了权限!
+
其实这个安全性限制原生 Android 也有,当然类原生 Android 也有,只不过需要 SIM 卡限制是小米自己魔改加上去的。
+# adb shell
+adb shell settings put secure install_non_market_apps 1
+adb shell appops set <package_name> REQUEST_INSTALL_PACKAGES allow
+
+或者安装Termux,并获取相应root权限后,使用 Termux 终端,在 shell 交互窗口设置也行:
+pkg install root-repo
+tsu
+
+settings put secure install_non_market_apps 1
+appops set <package_name> REQUEST_INSTALL_PACKAGES allow
+
+记得把<package_name>替换成相应的包名,比如 com.topjohnwu.magisk +
+多名网友反馈,讯飞输入法出现异常,从晚上7点多开始无法正常弹出键盘,点击提示则显示无法加载资源等。
要不是此次崩溃可能大家还没意识到讯飞输入法是完全依赖云端服务器的,即无法在离线的情况下使用,这个确实有些匪夷所思。
故障持续已经有两个小时,讯飞输入法官方没有发布回应,也没有完成修复;
+讯飞输入法官方微博在用户评论中回复:
+++您好,非常抱歉给您使用带来困扰~ 讯飞输入法在配置端午节运营活动过程中出现bug,导致部分用户出现客户端崩溃问题。输入法团队正在对此进行全力抢修,6月5日晚会发布新版本修复问题,新版本发布后、升级版本可恢复使用。 再次表示抱歉,感谢理解与支持~
+
另外根据网友反馈此次讯飞输入法崩溃只影响官方版,诸如小米定制版的讯飞输入法是正常的,这也可以看出来定制版使用的可能不是讯飞的服务器,所以并没有发生崩溃。
++所谓的"大数据"大头就在与输入法上传数据并推送个性化广告
+
Windows 设计史 01 | 从青涩到成熟(Windows 1.0 - 95)
+Windows 设计史 02 |「海王星」项目,「稳定」表象背后的求索
+Windows 设计史 03 | Windows XP:摆脱机械,拥抱自然
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+根据赛博昆仑实验室研究员Wei透露的部分消息,攻击者构造的IPv6数据包在到达防火墙进行数据处理之前就可能被触发,因此仅通过开启系统的IPv6防火墙并不能有效阻止攻击。
+结合该漏洞的特性,这进一步验证了之前的推测,即该漏洞可以用于在内网中进行横向攻击,特别是通过内网IPv6地址实施攻击。由于部分场景下的内网设备长期无法进行系统更新,该漏洞对这些没有网络隔离且长期无法更新系统的环境构成了更大的威胁。
+8月13日,民政部发布了新的《婚姻登记条例》修订草案,面向社会公开征求意见。草案对结婚和离婚程序进行了调整,取消了户口簿的要求,登记地点也不再受限。
+此外,新增了30天离婚冷静期的具体规定,“离婚冷静期“期间任何一方可申请撤回,并明确了隐瞒重大疾病可导致婚姻被撤销。草案还要求婚姻登记必须免费,确保个人隐私保密,并规定婚姻登记机关要提供婚姻辅导服务。(这部分细则看全文)
+韩国金融监督院8月13日表示,韩国移动支付服务商 KakaoPay 近六年来未经用户同意向中国支付平台支付宝擅自提供了 4000 万名用户的 542 亿条个人信用信息。据悉,为了满足与苹果公司合作的先决条件,支付宝要求 KakaoPay 提供全体用户的信用信息。而 KakaoPay 未经用户同意就提供了支付宝所要求的全部信息,其中甚至包括未使用过跨境支付服务的用户信息。根据双方合作内容,KakaoPay 用户可在与支付宝签署支付服务协议的线上线下商店进行支付。
+ArkTS API 11+ 可以启用检查网站安全风险的功能。开发文档显示违规和诈骗网站的检查是默认启用的,不能通过此接口关闭;风险网站的检查是默认关闭的,可以通过此接口开启或关闭。
+违规和诈骗网站的检查会发送 URL 哈希前缀和网站域名到服务器做检测,风险网站的检查会发送 URL 哈希前缀和脱敏 URL(删除 URL 的查询参数)到服务器做检测。
+Exploring TLS certificates and their limits
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+Aria 是一个高性能、轻量级、易于使用的文件下载框架,主要应用于 Android 平台,目前在 GitHub 上有超过 5600 个 Star。
+Aria 开发者写道:“因 Aria 被诈骗分子使用,导致我被跨省,因此本项目源码永久删除。”
+数周以来,巴基斯坦的互联网速度一直非常缓慢,但谁应该为此负责,这仍是一个有争议的问题。
+活动人士称,国家正在建设中国式的互联网防火墙,以进一步控制网络空间。官员们对这些说法提出质疑,并将爬行速度降低的原因归咎于安全连接或 VPN 的广泛使用。关闭互联网来压制异议是巴基斯坦和亚洲其他地区监管机构的常见做法。
自去年前总理伊姆兰汗引发骚乱以来,政府封锁了社交媒体平台,限制了网速,争取公众支持的斗争从街头蔓延到了数字空间。信息技术国务部长沙扎·法蒂玛周日表示,政府并不是近期网络放缓的原因。法蒂玛女士表示,“大量人口”一直在使用 VPN,“这给网络带来了压力,导致互联网速度变慢”。
++VPN应用在巴西应用商店下架
+
包括NordVPN、ExpressVPN和Surfshark在内的数十款VPN应用已经从巴西的苹果应用商店下架。根据Top10VPN的研究主管Simone Magliano的报告,至少有30款VPN应用消失了。著名的免费VPN提供商Proton VPN确认了这一问题,并猜测可能是“系统故障,或苹果在执行某种隐秘的审查命令。”
此事件发生之际,X(前称Twitter)刚刚宣布关闭其巴西业务,原因是该公司未遵守巴西最高法院法官亚历山德雷·德·莫赖斯的审查要求,否则其法律代表将面临逮捕的“秘密命令”。
AMD推出了最新的Adrenalin 24.8.1 WHQL驱动程序,为《黑神话:悟空》、《星鸣特攻》、《星球大战:亡命之徒》以及《使命召唤:黑色行动6》公测版等游戏提供支持。新版驱动还为《对马岛之魂导剪版》引入了Radeon Anti-Lag 2技术,该技术能够在开启FSR3帧生成功能时,在4K极高画质设置下降低RX 7800 XT显卡的延迟高达28%。同时,新版驱动扩展了HYPR-Tune支持范围,为《使命召唤:现代战争III》、《漫威蜘蛛侠:重制版》和《漫威蜘蛛侠:迈尔斯・莫拉莱斯》新增FSR 3自动配置,并宣布HYPR-Tune支持HYPR-RX以启用AMD FidelityFX等游戏内技术。
据 DMIT 援引中国电信集团北京公司的消息,中国联通现已确认拒绝接收任何来自中国电信CN2的国际路由。
+据了解,该变化影响中国联通用户接入CN2网络的能力,原先通过CN2 GIA的去程发生改变,回程目前未受影响。中国电信计划通过海外与中国联通进行互联以解决此问题。
DMIT 称,已注意到 AS4809(CN2)、AS23764(CGT) 与 AS10099(联通国际) 之间的对等网络出现拥塞,将接入香港、东京和洛杉矶的中国联通线路,以提高中国联通客户的网络质量。该运营商还重申了对 Pro 和 EB 系列产品网络质量的保证。
网络安全研究员Konstantin 发现,一个新的字符漏洞可导致 iPhone 和 iPad 崩溃。在滑动到 App 库后,在搜索框中输入 "":: 四个字符,将导致Springboard 重置,iPhone 会返回到锁屏界面。重置并非完全重启,iPhone 只需几秒钟即可恢复正常。
+测试发现,只需要输入 "": 和任何其他字符即可触发崩溃;重置问题似乎仅出现在运行 iOS 17 的设备上,iOS 18 设备上如此操作不会导致重置,但会出现一些奇怪的问题,例如字符消失和设置应用崩溃。
+A Starter’s guide on recovering damaged and rotten CDs
+在shell中将sing-box/mihomo作为客户端运行
+一个基于「 太微 TiddlyWiki 」的知识管理桌面应用
+一个开源的“即将推出”和 SaaS 平台和网站的等待列表页面
+Go语言写就的一个轻量级、自托管友好的 RSS 聚合器和阅读器
+基于自定义规则的番剧采集APP,支持流媒体在线观看,支持弹幕。
+一站式开源高质量数据提取工具,支持PDF/网页/多格式电子书提取
+一个开源的跨平台文件浏览器,由用 Rust 编写的虚拟分布式文件系统提供支持
+ + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+据新华社报道,泰国公共卫生部召开新闻发布会,称该国发现了首例猴痘Ib变异株病例。此次发现的该种变异株新增了可通过呼吸道飞沫等分泌物、皮疹、受感染物品等的传播途径。此外,包括中国在内的多个国家已开启针对入境人员的防疫措施。
两年前GRUB有个漏洞,能绕过安全启动机制;微软去修 Windows+Linux 的双OS用户的 GRUB 引导,修坏了...
+此次事件中受到波及的,是Windows+Linux的双系统用户。
安装更新后,这些用户在启动Linux时会发生报错,提示“出现严重错误”。
+Verifying shim SBAT data failed: Security Policy Violation.
+shim SBAT数据校验失败:违反安全策略
+Something has gone seriously wrong: SBAT self-check failed: Security Policy Violation.
+出现严重错误:SBAT自检失败:违反安全策略
+
+应急补救措施——
+首先进入BIOS关闭安全启动,目的是先进入到Linux系统。
之后利用命令行把引发故障的SBAT策略删除,然后重启让设置生效。
最后,再次进入BIOS重新打开安全启动,问题就暂时解决了。
+微软一直致力于为 Windows 添加新功能,同时也会淘汰一些不再必要的旧功能。这些功能会被添加到 Windows 过时功能列表中,最近的一个是 Paint 3D,微软宣布其即将被淘汰。与 Paint 3D 类似,微软似乎也希望尽快淘汰控制面板。
早在 2011 年,就有传闻称微软计划用“PC 设置”取代控制面板。虽然“PC 设置”的设计更加适合触摸操作,但控制面板仍然存在。
直到几天前,微软才在其网页上正式发布相关信息。在一个关于各种原生 Windows 配置工具的新支持页面上,微软终于表示,控制面板“正在被弃用,取而代之的是设置应用”。
+++控制面板是于 1985 年首次在 Windows 1.0 中引入的。
+
据法国媒体TF1 Info报道,加密通讯公司 Telegram 的创始人兼首席执行官帕维尔·杜罗夫 (Pavel Durov) 于法国时间24日晚上 8 点(北京时间周日凌晨 2 时)左右在勒布尔热机场的停机坪上从私人飞机上下来时被捕。这位 39 岁的法俄混血男子由他的保镖和一名女子陪同。
+根据通缉人员档案,杜罗夫从阿塞拜疆直接抵达。Telegram 创始人头上挂着法国司法警察局 OFMIN(隶属于法国海关部门的国家反欺诈办公室)签发的法国搜查令,该搜查令在初步调查的基础上签发。
法国当局认为,Telegram 缺乏审核、与执法部门的合作以及其提供的工具(一次性号码和加密货币)使其成为贩毒、恋童癖和欺诈的帮凶。但该搜查令只有当帕维尔·杜罗夫在法国国土上时才有效。
当前,ONAF 的调查人员通知了他并将其拘留。他应该在本周六晚上被送交调查法官,然后周日可能会因多项罪行被起诉:恐怖主义、毒品、同谋、欺诈、洗钱、收受赃物、儿童犯罪内容等。
++Toncoin 价格 已下跌17.4%,部分交易所出现 20% 以上的剧烈跌幅
+
中国将于2024年9月1日起实施新的《无线充电(电力传输)设备无线电管理暂行规定》,规定无线充电设备的工作频率和额定传输功率。MagSafe和Qi2协议使用的频率为360kHz,不符合新规要求的频率范围,可能面临停售。工信部明确指出,325-405KHz频段在中国不可用于无线充电设备。苹果官网已更新iPhone的无线充电参数,显示额定传输功率为7.5W,工作频率为127.7kHz,符合新规。
苹果iPhone 15等机型目前仍显示支持MagSafe与Qi2无线充电,最高功率达15W。新规施行后,不符合要求的设备将停止生产或进口,但已生产或进口的设备可继续销售至报废。新规对无线充电设备市场及苹果产品销售策略可能产生影响。
《一人企业方法论》第二版,也适合做其他副业(比如自媒体、电商、数字商品)的非技术人群
+Supersonic:自托管音乐服务器的轻量全功能跨平台桌面客户端
+ + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+广州家电以旧换新补贴(京东平台)现已开始发放,包含冰箱、洗衣机、电视、空调、电脑、热水器、吸油烟机、家用灶具。
虽然名为“广州以旧换新”,但目前广东省内都可领取。
+与北京补贴不同的是,本次下单地址限广东省内。
每人 8 个品类每种都可参与一次,单次至高补贴 2000 元,合计至高可减 16000 元。
+本次活动于 2024 年 9 月 1 日开启,预计结束时间为 2024 年 12 月 31 日。
7 月份时红帽工程师基于 systemd 255 + 版的全屏显示错误消息功能为 Linux Kernel 开发崩溃后显示二维码选项,这与微软在 Windows 10/11 蓝屏死机后显示二维码有异曲同工之妙。
+不过 Linux 与 Windows 在崩溃时显示的二维码内容则有本质区别,因为 Windows BSOD 显示的二维码实际就是微软帮助文档的链接,属于固定内容二维码。
+Linux Kernel 的崩溃后显示二维码是将崩溃日志生成二维码,这样崩溃日志不会被截断,用户在必要的时候对二维码进行拍照以后后续解码内容分析崩溃的具体原因。
经过两个月的讨论后目前红帽工程师准备的代码已经通过 DRM-Misc-Next 提交给 DRM-Next,以便能够赶上 Linux Kernel 6.12 的合并窗口,如无意外的话 Linux Kernel 6.12 将是首个支持崩溃后显示二维码的内核版本。
值得注意的是显示二维码功能是红帽工程师使用 Rust 语言编写的,因此必须启用 Rust 内核构建后才能使用此功能,在构建中可以通过 DRM_PANIC_SCREEN_QR_CODE Kconfig 作为功能开关配置。
9月1日,2024版《中国国家铁路集团有限公司铁路旅客运输规程》(简称《国铁集团客规》)在铁路12306网站全文发布。特别的,第三十五条明确,旅客要求越过车票到站继续乘车时,须在原车票到站前提出,在有运输能力的情况下列车可予以办理,核收越站区间的票款;无运输能力时,列车有权拒绝旅客补票和继续乘车。
有铁路工作人员此前介绍,平时铁路运能充裕,可以为旅客办理“买短乘长”补票。但买短乘长又往往集中出现在运能紧张的客流高峰时期,这时,工作人员会根据客流情况,决定是否办理越站补票手续。如果列车旅客过多影响到运行,就不会办理补票,“买短乘长”的旅客可能会被劝导下车。
+烟草局计划建立一个统一的电子烟交易管理平台。该平台将执行统一标准,确保电子烟合法销售。电子烟、雾化物和烟碱生产企业、电子烟批发和零售商等各类电子烟市场主体应当通过平台进行交易。
同时坚持市场决定价格,建立完善主要由市场调节的电子烟产品价格形成机制。
+此外,进口电子烟同一规格实行全国统一销售价格,并在平台上公开。
+今天,谷歌正式向安卓开源项目 (AOSP) 推送安卓 15 的源代码。安卓 15 将在未来几周内在受支持的 Pixel 设备上推出,并将在未来几个月内在三星、荣耀、iQOO、联想、摩托罗拉、Nothing、OnePlus、Oppo、realme、夏普、索尼、Tecno、vivo 和小米的精选设备上推出。谷歌在博客文章中表示,我们很自豪能够通过 AOSP 继续开展开源工作。开源允许任何人以安卓为基础进行开发和贡献,从而打造出更加多样化和创新的设备。
从多位知情人士处获悉,淘宝平台拟全面引入微信支付,成为阿里系平台与腾讯之间互通的标志性事件。据了解,淘宝打通微信支付在淘天集团内部属于保密项目,该项目的筹备始于半年前,由用户端基础工具团队在主要对接。今年6月,手淘已有部分用户灰测使用微信支付,不过仅支持购买部分商品时可选择。据了解,淘宝接入微信支付这个项目,淘天是更加积极推动的一方,此举从业务到战略层面,对阿里都有重大意义。
Bangumi for Android - 适用于 bangumi.tv 的功能齐全的非官方 android 原生应用程序
+ + + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+9月10日,有消息称阿里云新加坡节点出现网络崩溃情况。
+相关工作人员表示,阿里云新加坡地域可用区C网络访问出现异常,阿里云的工程师正在紧急处理中。该工作人员还补充道,出现异常是由于新加坡机房出现火灾。
+据了解,阿里云成立于2009年,是一家云计算和人工智能科技公司。
+今年7月份,阿里云也曾出现网络异常问题。彼时,阿里云发布消息称,阿里云监控发现上海地域可用区N网络访问出现异常,经阿里云工程师紧急介入处理后,于当日10:35完成网络切流调度后,10:42访问异常问题恢复。
+目前云服务ECS、对象存储、云数据库等仍然未恢复,中断时间已超48小时。
+此次事件导致如PikPak、Lazada(东南亚最大电子商务平台)、字节海外服务均受影响,PikPak目前服务仍不稳定。
+微软公司称用户可能无法从 AT&T 公司网络访问其 Azure 云服务,并正在调查可能发生的中断事件。微软还确认 Microsoft 365 服务目前已停止服务,该问题影响了 Teams、Outlook 以及更多服务。
+据 Downdetector 数据,截至美国东部时间上午 8:58,已报告约 21,000 起 Microsoft 365 中断事件。
+2024年9月12日,人工智能领域的领军企业OpenAI宣布推出全新的o1系列模型,标志着AI推理能力的重大突破。这一系列模型专门设计用于解决复杂问题,在科学、编程和数学等领域展现出前所未有的性能。
+o1系列的核心创新在于其独特的"深度思考"机制。通过先进的训练方法,模型能够在生成回答前进行更全面、深入的推理过程。这种方法使AI能够:
+尝试多种解决策略 +识别并纠正推理过程中的错误 +逐步优化思考路径
+在严格的性能测试中,o1系列模型展现出卓越表现:
+国际数学奥林匹克竞赛(IMO)资格考试:o1模型正确率达83%,远超GPT-4o的13% +Codeforces编程竞赛:达到89百分位水平 +物理、化学、生物学等领域:表现接近博士生水平
+OpenAI为o1系列开发了创新的安全训练方法,充分利用模型的推理能力来加强安全性:
+"越狱"测试:o1-preview模型得分84分(满分100分),大幅领先于GPT-4o的22分 +新的安全训练方法使模型能够更好地理解和应用安全准则
+为满足不同应用需求,OpenAI同时推出o1-mini模型:
+运行速度更快,成本降低80% +保留强大的推理和编程能力 +适用于需要高效推理但不需要广泛世界知识的场景
+为什么每个 User-Agent 都有 Mozilla 字样?
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+微软在今年7月的蓝屏危机后曾讨论过完全封闭 Windows 的内核。近期微软再次发布一篇文章称,「公司正致力于为内核模式之外的解决方案提供商提供更多安全功能」。
+现在许多游戏都使用了内核级别的反作弊程序,但是许多开发商关闭了Linux兼容层,导致 Linux 无法通过 Proton 或是Wine来运行这些 Windows 游戏。随着主流系统更新,内核级的反作弊、客户端的反作弊或将逐渐淘汰,服务器端反作弊方案将成为新选择。不论是从游戏性能还是安全角度,或是设备系统兼容,这对于玩家来说都是一件好事。
+当地时间9月16日,Intel首席执行官帕特·基辛格 (Pat Gelsinger) 在最新的股东大会之后,发布了一封公开信,对于近期相关传闻进行了回应,并全面概述了Intel的转型计划。
+在8月初公布了糟糕的财报及财测数据,并宣布全球裁员15%、削减资本支出(到2025年削减100亿美元资本支出)、暂停每季派息之后,Intel受到了来自投资者、政府、内部员工、社会舆论等诸多方面的巨大压力。
+由此,也引发了诸如“Intel将出售晶圆制造业务”、“Intel将出售FPGA(Altera)业务”、“高通将收购Intel部分芯片设计业务”、“Intel将暂停海外晶圆厂建设”等一系列的传闻。
+2024年9月18日——Mozilla 宣布将于2024年12月17日停止其社交平台 Mozilla.social 的实验,届时 Mastodon 实例将正式关闭。用户仍可在12月17日前继续使用 Mozilla.social,并在此日期之前下载相关数据或将账户迁移至其他 Mastodon 实例。
+12月17日之后,Mozilla.social 的 Mastodon 实例将彻底关闭,平台上的所有内容和账户将无法再访问。不过,用户的 Mozilla 账户仍将继续有效,可以用于访问 Mozilla 的其他产品和服务。用户可以通过 Mozilla 官网管理其账户信息。
+在近期的 Mate XT 交付仪式上,华为消费者业务 CEO 余承东说,华为的个人电脑产品将全面弃用 Windows 系统,转而采用自家研发的鸿蒙操作系统。主要受到美国制裁的影响,华为加速了技术自主化的进程。
+余承东表示,华为已经能够完全替代美国的技术和元件,未来的新一代笔记本将提供与 Mac 类似的操作体验,旨在打造统一的生态系统,提升用户体验。鸿蒙系统的成功将直接影响华为在全球市场的竞争力。
+近日在奥地利举办的开源峰会(Open Source Summit)上,亚马逊宣布将其旗下OpenSearch开源项目捐赠给 Linux 基金会,该基金会已经成立 OpenSearch 软件基金会,用来支持该项目及其搜索和分析软件的研发。
+OpenSearch 是 Elasticsearch 和 Kibana 的开源分支,现在已正式成为 Linux 基金会开源项目家族的一部分。Linux 基金会表示,OpenSearch 被世界各地的软件开发人员用来构建搜索、分析、可观察性和矢量数据库应用程序,下载量业已超过 7 亿次。OpenSearch 软件基金会将与社区维护者和开发人员以及创始成员组织合作,支持 OpenSearch 的持续发展。
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+近日,CloudFlare WARP 客户端更新后带来了 MASQUE 协议支持,用户可以在客户端设置菜单中进行切换。MASQUE 是基于 HTTP/3 和 QUIC 的新协议,能高效代理 IP 和 UDP 流量,同时保持性能和隐私。该协议还将使 WARP 的流量看起来像 HTTPS,以避免被防火墙检测和阻止,并符合 FIPS 标准的加密。
+客服表示,车内换座功能是近期刚上线的,具体来看,车内换座属于中转票的一种,是分段售卖,之前需要消费者一段一段去查,现在是12306系统可以优先算出这一趟车的线路并做出提示,用户可以分段购买同一趟车次的车票,到了中转站在车上直接换座即可。“其实就相当于买了两段行程,只不过两段行程是在同一辆车上,不需要换乘。”客服表示。
+上述客服称,价格方面,会比直达的车票贵一些,“因为是分段售卖,每段加起来的价格一般会比直接买全程价格高。”
+12306平台另一客服也表示,车内换座是为没抢到直达车票的用户提供的功能,即使有优惠的话分段票价加起来也比直达的要贵。
+中新经纬查询发现,并非每趟列车都有车内换座功能,且车内换座的价格确实比直达票价要贵一些。
+以9月30日北京南到上海虹桥站,6点10分发车的G101次高铁为例,二等座直达票价为626元,如果选择中转,在南京南进行车内换座,二等座的价格为504元(北京南到南京南)+153元(南京南到上海虹桥)共657元,两者差31元;一等座价格分别为1035元(直达)和1086元(车内换座),两者相差51元;商务座价格为2318元(直达)和2432元(车内换乘),相差114元。
+OpenSSH 9.9 新增并默认启用了对 mlkem768x25519-sha256 混合量子抗性密钥交换算法的支持。该算法巧妙地结合了 FIPS 203 模块格密钥封装机制 (ML-KEM) 和 X25519 椭圆曲线 Diffie-Hellman (ECDH),大幅提升了系统抵御量子计算威胁的能力。
+在国务院新闻办公室今天举行的“推动高质量发展”系列主题新闻发布会上,国家广播电视总局透露已研发出能够同时控制电视机和机顶盒的新型三模通用遥控器,广电总局广播电视科学研究院也已经研制了 8 款只有 U 盘大小、可以隐藏在电视机后面的微型机顶盒。
+目前中央和省级电视台已经全部实现了高清化播出,地市台频道高清化率已经超过 98%,全国已经开办了 9 个超高清频道。有线电视网络和 5G 协同发展,广电 5G 用户已经超过了 2800 万。网络视听持续繁荣,用户规模已经达到 10.68 亿。
++ ++
云手机底层技术揭密 : Android系统启动与Magisk原理
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+早前小米已经对澎湃 OS 国内版施加解锁限制,要想申请解锁 Bootloader 必须参与答题以及积极参与小米社区并在社区等级达到 5。
+现在小米澎湃 OS 国际版也开始限制,倒不是非得参与什么社区,而是用户申请时总是提示名额已经用尽需要等待几天再申请。
+在小米澎湃 OS 海外社区申请解锁的贴子中大量国外网友在抱怨小米施加的限制,显然这不可能是突然大量用户申请解锁导致名额用尽,而是小米故意施加的限制但没有公开披露。
+有网友抱怨自己尝试了几个月都没有拿到解锁名额解锁自己的小米手机,抱怨小米给消费者制造麻烦,当然更大的问题是没有透明度,小米既没有公开披露为什么要限制也没有披露什么时候才能恢复正常。
+对消费者来说目前最大的问题就是不能解锁那也无法刷机,部分玩家爱好者希望解锁 Bootloader 就是希望能够刷机或者对 ROM 进行微调,例如可以使用 Magisk+ROOT 权限获得更多功能。
+小米暂时还未对此事进行回应,所以还不清楚小米为什么要施加限制,但考虑到现在已经不是刷机时代,小米应该也不至于担心是刷机造成自己的广告费流失吧。
+9月28日消息,公安部网安局发文称,浙江省绍兴市新昌公安破获一起非法抢单外挂软件案,涉案金额达3000余万元。
+该作案团伙上下游分工明确,结构清晰,从软件开发到渠道销售、运维等,全链路均涉及,并由不同人员负责。
+这个外挂软件名叫“死神”,并先后迭代12个版本,演化为“雷神”“波点”等多个软件,在全国范围内均有兜售。
+非法销售外挂软件的人员宣称,外卖骑手花几十块钱买一个激活码后,即可非正常抢单。此类外挂软件通过非法读取各类App的订单框架,设置抢单条件,实现自动化、定制化抢单功能。
+在美团安全团队的支持配合下,新昌公安经过对线索的全面收集和深入研判,已抓获违法犯罪嫌疑人112名(其中,刑事打击14人,行政处罚2人),批评教育71人。
+目前,该案中为首的犯罪嫌疑人被依法判处有期徒刑三年半,案件仍在进一步侦查办理中。
+根据兵库县警察公开的信息显示,兵库县警察局对本部安全科的一名 50 多岁男性警司持续要求 21 名下属在在线购物应用 Temu 并注册的行为进行了警告。该应用允许那些推荐朋友的人获得特殊福利,当事人说:“我就是想要一份礼物。”据县警方称,3月至6月期间,该男警司通过LINE等渠道向其手下的21名男警官发送信息,称“免费注册”、“请帮我们获得5份免费礼物”等内容。他敦促他们注册成为 Temu 的会员。一些下属在与另一位上级协商后发现了这一事件。在县警察进行的一项调查中,21 人中有 12 人表示他们对该应用感到“不舒服”,15 人在注册后立即删除了该应用。
+10 月 2 日消息,Cloudflare 今日发文称,其 DDoS 保护系统自 9 月初以来一直在抵御一个超大规模的 L3/4 DDoS 攻击。
+此次攻击一直持续了一整个月,期间包括一百多次超大规模攻击,其中最大一次攻击达到 3.8Tbps,是已公开过的最大规模的一次攻击。
+Cloudflare 表示,这些攻击主要利用固定端口上的 UDP,且源自全球各地,占比较大的数据来于越南、俄罗斯、巴西、西班牙和美国。
+此次攻击活动针对的是金融服务、互联网和电信等行业的多个客户。此次攻击活动的目标是带宽饱和以及在线应用程序和设备的资源耗尽。高数据包速率攻击似乎源自多种类型的受感染设备,包括 MikroTik 设备、DVR 和 Web 服务器,这些设备协同工作,向目标发送大量流量。高比特率攻击似乎源自大量受感染的华硕家用路由器,可能是利用了 Censys 最近发现的 CVE 9.8(严重)漏洞。
+8月16日,微软推送了Windows 11 Build 27686预览版更新,除了全新的Windows Sandbox Client预览版外,在格式化命令从命令行格式化磁盘时,FAT32的大小限制也从32GB提高到了2TB,这意味着现在即使是2TB的U盘或移动硬盘,也可以使用FAT32格式。
+FAT32是1995年随Windows 95 OSR2一同发布的文件系统,它继承了FAT16的优点,并解决了后者单个分区大小不超过2GB的问题。理论上FAT32支持的存储容量可以达到16TB,但Windows系统之前将其限制在32GB,这主要是其原理上的缺陷。
+一方面,FAT32几乎都用在U盘、存储卡等移动存储设备(硬盘从WindowsNT后开始逐步普及NTFS),而早期这些移动存储设备容量普遍偏小,如果默认的簇偏大就会造成磁盘空间的浪费,即使小到几个字节的超微型程序,也会占用完整的32KB存储空间,所以微软才做出如此的限制。
+除此之外,FAT32在原理方面的缺陷,还容易产生严重的文件碎片,从而影响读写速度,这也是Windows95/98操作系统内置磁盘碎片清理的原因。不过,FAT32无法处理超过4GB的单个文件,这对于高清视频、大型数据库或虚拟机镜像等应用场景来说是致命的。
+虽然NTFS克服了上述的问题,同时还拥有极高的安全性,但基本仅限于Windows系统使用,其他的操作系统例如macOS、Linux等无法直接读写,而数码相机、智能手机和平板电脑也不支持,因此FAT32依然是移动设备最常用的文件系统。
+为了解决FAT32存在的问题并适应日益增长的数据存储需求,微软于2006年推出了exFAT(Extended File Allocation Table),但直到近些年才被发扬光大,例如一部1080P的蓝光电影普遍超过10GB,这时候除了NTFS,可用的磁盘格式也只能是exFAT了。
+exFAT保持了与多种操作系统的良好兼容性,尤其是在日常生活中,移动硬盘、U盘和存储卡等经常会遇到需要跨越不同平台进行数据交换的情况,而exFAT凭借其出色的跨平台兼容性和高效稳定的特性,成为了许多用户的首选,几乎所有的操作系统和设备都能完美支持。
+更重要的是,exFAT可以支持的最大卷尺寸几乎是无限的,即使是多TB级别的硬盘也能被有效利用,而且不受限于4GB的天花板,用户可以轻松地传输任何大小的媒体文件或其他类型的大文件。同时,更先进的算法极大减少了磁盘碎片产生的可能性,提升了整体效率。
+FAT32曾经是许多人记忆中不可或缺的一部分,但毕竟廉颇老矣,即使分区限制提升到了2TB也无法有效满足需求,一方面是单个多媒体文件早已超过4GB,另一方面移动固态硬盘的容量也已经达到了8TB,因此exFAT格式才是跨系统、跨平台移动存储的唯一选择。
+一文讲清CPE、MiFi和物联卡:是「流量自由」还是「坑蒙拐骗」?
+UniGetUI:包管理器的图形界面。可以被糟糕地描述为管理包管理器的包管理器
+ + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+除了光标消失问题,Windows 11 24H2 更新还会导致创建一个无法使用磁盘清理删除的 8.63GB 更新缓存。虽然 Windows 更新缓存非常正常并且在磁盘清理或存储清理等工具中可见,但 Windows 11 24H2 中的一个奇怪错误阻止了用户清除更新缓存或文件。磁盘清理和存储设置尝试删除更新缓存文件,但不起作用,缓存一直占用高达 8.63 GB 的存储空间。Windows 11 修复安装也无法解决此问题,但全新安装确实可以解决问题。微软公司表示,已经注意到用户的反馈,并计划在即将发布的更新中发布修复程序。
+Google 正在为 Android 开发一个官方的 Linux 终端应用。这个应用将允许用户在 Android 设备上运行 Linux 命令,类似于 Chromebook 上的 Crostini。
+开发人员可以通过开发人员选项启用终端应用程序,并将在虚拟机中安装 Debian。
+海康威视正在实施大规模的组织调整,32个研发区域将收缩至12个,预计裁员规模将超过1000人,研发部门受影响最为严重。部分被裁员工透露,裁员会有“N+2”的赔偿方案,部分地区如湖南已经完成裁员,杭州总部尚未开始。
+近年来,公司营收和净利润增速下滑,2024年第二季度净利润同比下降10.7%,低于市场预期,增收不增利的局面尤为突出。软件业务收入占比下降,进一步加剧了公司的增长压力。
+Lem 是专为 Common Lisp 调整的编辑器/IDE
+ + + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+Windows 11 24H2 更新导致某些 PC 崩溃并出现蓝屏死机 (关键进程已死亡)。微软已经意识到了这一点,并计划暂停今年在受影响硬件上的更新。据透露,微软已经意识到少数搭载西部数据特定 SSD 的设备可能会遇到蓝屏死机错误的问题。蓝屏死机与存储驱动程序和 RAID 控制器有关。WD SN770 会提供 200MB 主机内存缓冲区 (HMB),而 23H2 只会分配 64MB 所以没有问题,然而 24H2 会分配完整的 200MB ,并导致蓝屏死机错误“关键进程已死亡”。用户虽然可以通过设置注册表“HMBAllocationPolicy = 0”关闭 HMB 来缓解该问题,但可能会影响硬盘性能。
+The story of Ubuntu is a story written by many hands. This page is a tribute to our community, partners and Canonical staff who have all given a piece of themselves to making this open source project thrive. Thank you to all of you. +Ubuntu的故事是由许多人书写的故事。 此页面是向我们的社区、合作伙伴和 Canonical 员工致敬,他们为使这个开源项目蓬勃发展做出了自己的贡献。 谢谢大家。
+Above all, it’s a celebration of what Ubuntu has achieved so far, and an invitation to collaborate with us in delivering an even faster pace of innovation in the future. +最重要的是,这是对 Ubuntu 迄今为止所取得的成就的庆祝,并邀请我们与我们合作,在未来提供更快的创新步伐。
+日前,Linux 内核主要维护者之一 Greg Kroah-Hartman (Greg K-H) 提交了一项不寻常的“文档”更新,将数名具有 <.ru> 顶级域名邮箱的维护者,和一名明确为俄罗斯身份的维护者从 MAINTAINERS(维护者名录)文件除名。
+这一提交已于上周日被 Linus Torvalds 拉取并包含于 6.12-rc4 版本的代码中。
+Greg K-H 并未详述这项更新的具体原因,仅含糊其辞地表示该更改是“由于某些合规性要求”,并指出“(相关人员)提供充足文档后,方可回归(维护者名录)”。
+相关的维护者移除方式相当暴力,其中部分子系统由于唯一维护者使用 <.ru> 顶级域名邮箱,整个子系统都被从 MAINTAINERS 文件中移除,这之中不乏诸如 UFS 文件系统和 PPTP 驱动等重要且被广泛使用的子系统。由于 Linux 内核开发流程完全基于邮件列表进行,当 MAINTAINERS 文件中移除相关维护者后,也就意味着与相关子系统的补丁或沟通将不再被发送至维护者的邮箱,乃至相关的邮件列表。这很可能会造成许多补丁“石沉大海”;而如果某个子系统未得到充分维护,那么其被从内核中移除也只是时间问题了。
+通常而言,Linux 内核补丁除了发送至邮件列表外,还需要抄送与之相关的人士(如子系统维护者和活跃贡献者),并且经过讨论和审阅后才会被拉取合并。然而,Greg K-H 似乎刻意绕过了这部分流程,仅仅将补丁发送至流量最大、几乎不会有人认真阅读每封邮件的 patches@lists.linux.dev 列表,并于仅仅两天后就向 Linus Torvalds 发起拉取请求,而 Torvalds 亦未对相关修改提出质疑和意见便拉取合并这笔更改了。
+考虑到 Linus Torvalds 与 Greg K-H 均受雇于 The Linux Foundation,后者为注册在美国的 501(c)(6) 组织,“某些合规性要求”为何显而易见。
+截至发稿时,Greg K-H 尚未回应邮件列表上的相关质询。无论结果为何,这都将是 Linux 内核社区历史上最为耻辱的提交之一。
+RackNerd 服务状态显示,其位于洛杉矶DC-02 所在的大楼出现火警,洛杉矶消防局因此切断了供电,DC-02的所有服务器受到影响。RackNerd 强调该公司服务器所在楼层没有火灾,因此数据是安全的。
+据了解,RackNerd DC-02由跨国宽带网络服务提供商 MultaCom 直接运营。另外一家运营商 CloudCone 也在此处托管有大量服务器。今天CC同样出现了大面积服务中断,截止目前该公司尚未发布通告。
+egos-2000 :仅用 2000 行代码就实现了教育操作系统的每个组件
+ + + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,暂定每周四进行更新.
+近日一份文件显示,宁德时代向员工发出了“奋斗100天”的号召。即符合条件的员工从6月12日起,施行896的工作日,即早上8点上班,晚上9点下班,每周工作6天,共“奋斗”100天。
+另外,还有补充通知说明:外籍员工不强制,按照他们的意愿。据了解,此次已不是第一次宁德时代号召“奋斗100天”,早在2022年的一篇报道中,宁德时代就被提到:奋斗100天已成常态化。
+++宁德时代内部员工回应“896工作制”
+
今日有消息称,宁德时代向员工发出了“奋斗100天”的号召,即符合条件的员工从6月12日起,施行“896”的工作日,即早上8点上班,晚上9点下班,每周工作6天,共“奋斗100天”。有宁德时代内部员工对财联社记者表示确有此事,上周五部门开会口头通知此事,并表示:“之前是也要加班,但不强制到九点。”另有知情者透露,该号召是针对一定级别以上员工,并非所有员工。截至发稿前,宁德时代官方尚未对财联社记者给予回复。
+6月18日,Steam平台最新一周销量榜出炉(6月11日-6月18日),国产游戏《黑神话:悟空》再次登顶,达成全球二连冠。而在前一日晚间,《黑神话:悟空》在京东开启第二轮PC实体版预售几乎秒售罄,与第一轮情况相同。
+根据官方信息,《黑神话:悟空》PC实体豪华版售价820元,限量20000套;收藏版售价1998元,限量10000套。目前豪华版预约人数已超过20万人,收藏版预约人数已超过41万人。
+这款游戏的开发商游戏科学成立于2014年,由原腾讯《斗战神》网游项目核心成员冯骥和杨奇等人创立,其中冯骥是《斗战神》项目的主策划。
+在采取更加大力度的降价策略后,苹果继续把持京东相关排行榜的第一位。截至19日6点18分,在京东618手机竞速榜上,苹果拿下了手机品牌销量与销售额的双料第一。单品方面,其iPhone 15 Pro Max、iPhone 15 Pro以及iPhone 15,分别拿下第一、第二和第四。
+过去半年来,苹果已多次以官方名义降价促销,在竞争激烈的中国市场“贴身肉搏”。事实证明,这一策略收效甚好。苹果之外,小米再次拿下国产品牌阵营第一,其在京东、天猫、拼多多、抖音、快手等平台上均为国产手机销量及销额的双第一。小米在今年618中出现了明显增幅。截至18日24时,小米618大促全渠道累计支付金额达到263亿元,创出其历年大促的新纪录。
+最新的 Android 15 测试版中操作系统框架中的字符串显示,系统会自动检测面部或指纹模型何时效果不佳,并删除它们,然后提示用户重新设置。将显示一条通知,提示您的面部或指纹模型“运行不正常,已被删除。请重新设置以使用您的脸部或指纹解锁手机”。由于安卓只允许注册一个面部模型,因此重新注册面部时显示的通知与重新注册指纹时显示的通知略有不同,但功能上没有区别。目前尚不清楚系统是如何判断生物识别数据效果不佳的,甚至不确定是否在最新的 Android 15 测试版中上线。
+法国巴黎法院在5月份应版权方要求,命令谷歌、CloudFlare 和思科在其公共 DNS 系统里屏蔽约117个盗版网站域名。此次屏蔽的网站主要涉及的版权内容是英超联赛和欧冠联赛,提交申请的版权方则是 Canal+,该版权方还要求法国当地 ISP 即网络运营商也通过 DNS 系统屏蔽这些域名。通过相关公开数据谷歌代表律师认为这大约影响了800多名法国用户,所以实际影响可以说微乎其微或者说完全没有。
+19日,上海市公安局城市轨道和公交总队官方微博发出通报称,早上8时28分,轨交9号线合川路站内发生一起持刀伤人案。54岁犯罪嫌疑人沈某(男)行凶后,导致3人受伤。沈某被抓。
+网传视频显示,地铁内多处有血迹,其中一名男子倒地,多名工作人员互相呼叫、前来包扎施救。现场有的民众快速离开,有的在远处围观。
+网民猜测:“54岁中年失业男?上次吉林市北山公园那个也是55岁中年失业男。”网民所说“吉林市北山公园”事件市指,6月10日,美国爱荷华州康奈尔学院(Cornell College)4名教师在吉林省吉林市北山公园被刺伤。行凶者为55岁吉林市龙潭区男子崔某某。
+那些原本是废话的常识|小学生吐槽食堂之后:看,社会又来教“做人”了
+飞鱼 : 一个漂亮的跨平台视频播放器,支持docker部署。
+Nullboard : 是看板/任务列表管理器的极简风格,设计紧凑、可读且易于使用。单页 Web 应用程序 - 只有一个 HTML 文件、一个古老的 jQuery 包和一个 webfont 包,可以完全离线使用。
+OnionPlay : 一个免费提供最新电影和电视剧在线播放的网站,无广告干扰。
+Z-Library图书馆 : 可以使用的官方域名大全。
+开源大模型食用指南 : 基于Linux环境快速部署开源大模型。
+中小学人教版教材下载 : 内容全面,速度快
+小初高电子教材免费下载页(WEB在线下载) : 无需登陆,下载稍慢,次数有限
+ +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+近日,哔哩哔哩对大会员服务协议内容进行了更新和优化,更新版本主要针对使用限制的情形相对应的条款进行调整:(一) 同一账号同一时间最多可以在2个终端设备使用会员服务,终端设备包括但不限于手机端、电脑端、平板电脑端、网页端等 (包括小程序) 以及上述终端相应的网页端;(二) 同一账号在手机端24小时内至多支持在2个设备上使用会员服务;(三) 超过上述范围使用的,哔哩哔哩大会员将会根据情况中止或终止对您提供的服务,且哔哩哔哩大会员保留采取进一步措施的权利,包括但不限于追偿损失等。
+近日,7-Zip被曝出编号为CVE-2025-0411的高危漏洞,该漏洞允许远程攻击者绕过Windows的“网络标记”(Mark-of-the-Web, MOTW)保护机制,从而在受影响的系统上执行任意代码。此漏洞影响24.07及之前的所有7-Zip版本,建议用户尽快升级至24.09版本以修复漏洞,确保系统安全。
+NVIDIA CUDA将「冻结」三大老架构
+NVIDIA在最新的CUDA 12.8开发包更细日志中明确表示,针对Maxwell、Pascal、Volta三大老架构的支持,已经完成了所有功能特性,未来的新版本中将处于「冻结」状态。CUDA开发包仍会继续支持它们,但不会有任何新功能。
+据用户反映并通过微软客服专员证实,微软已在全球范围内下架E5开发者订阅。
+此消息意味着,长期以来被许多用户视为免费网盘福利的E5订阅及其附带的大容量云存储空间,即将成为历史。
+用 nextUI 写的阅读体验更好的 Miniflux 第三方 Web 前端
+Serial Studio能够与串行端口、网络套接字和 MQTT 代理进行交互
+Ghostty 是一款快速、功能丰富且跨平台的终端仿真器,它使用平台原生 UI 和 GPU 加速。
+一款无服务端的多协议云盘文件上传和管理应用,支持多种存储协议,包括本地文件、FTP、SFTP、S3、SMB、Webdav等
+ +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+Cloudflare采用由Adobe主导的“内容凭证”系统,为图片和视频添加数字元数据标签,追踪其所有权、发布历史以及是否经过篡改,特别是是否使用了生成性AI工具。
+Cloudflare还推出了一个“保留内容凭证”的一键设置功能,适用于所有通过Cloudflare Images托管的内容,用户可以通过Adobe的“内容真实性”网页工具或Chrome扩展程序,轻松验证这些图片的数字历史。
+该系统基于“内容来源与真实性联盟”(C2PA)制定的开放标准,旨在帮助艺术家和摄影师保留作品的归属权,并帮助用户区分真实和经过AI工具生成或篡改的图像与视频。
+苹果正式宣布将 Swift Build 开源,并纳入 Swift 项目,致力于为所有 Swift 用户提供更强大且统一的跨平台构建体验。Swift Build 作为 Xcode 的底层构建引擎,已为数百万 App 和苹果自家操作系统构建流程提供支持,现开源后也可面向 Linux、Windows 等平台。
+Swift Package Manager 将逐步采用统一引擎,确保在所有平台和工具中获得一致的构建体验,并为后续新功能和性能改进铺平道路。目前,Swift Build 已在 GitHub 的 Swift 组织下公开,社区开发者可提交反馈与改进建议,共同推进这一新里程碑的发展。
+此插件是 Project Bergamot 的一部分,后者由欧盟资助,旨在提升浏览器离线机器翻译的效果。
+插件目前支持 12 种语言,包括德语、西语、俄语、葡萄牙语、意大利语等。
+一位小米工程师向 AOSP 提交了一个补丁,该补丁将添加一个 SELinux 策略,禁止用户通过 adb 等方式来提取 APK 文件,理由是 APK 中可能会包含一些「私有资源」。
+该补丁提交后,在 AOSP Code Review 中引起热议。该工程师称,“APK 只应该从谷歌市场或其他应用市场等可靠来源获取,如果一个 APK 可以被 adb 提取,它就可以被反编译,这样会有一定的安全风险。”。有网友在下面顺势质问小米不开源内核,小米并未对此答复。
+好在 Google 拒绝将此补丁合入 AOSP,并称“APK 基本上不是(原文大写强调)秘密”,但 Google 拒绝合并并不意味着 MIUI 不会采取措施来进一步限制用户权限,好时代,来临力🤮
+1 月 20 日,DeepSeek 发布了全新的开源推理大模型 DeepSeek-R1,在数学、编程和推理等多个任务上达到了与 OpenAI o1 相当的表现水平,同时将API调用成本降低了 90-95%。
+和上次不同的是,这次推出的新模型DeepSeek-R1不仅成本低,更是在技术上有了大福提升。
+AI圈大V Yuchen Jin认为,DeepSeek-R1 论文中的这个“顿悟时刻”意义巨大:纯强化学习 (RL) 使LLM自动学习思考和反思。
+这挑战了之前的观点,即复制 OpenAI 的 o1 推理模型需要大量 CoT 数据。事实证明,你只需要给予它正确的激励即可。
+在PDF里运行Linux,利用RISC-V模拟器,将Linux系统嵌入PDF文件,基于TinyEMU,支持32位和64位系统;
+ +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,这周三提前一天更新.
+朱利安·阿桑奇(Julian Assange)在同意对违反美国《间谍法》的一项指控认罪后已经出狱。预计本周在北马里亚纳群岛的美国法庭出庭后,他将获得自由。26日,阿桑奇承认了一项“共谋获取和披露国防信息”的刑事指控。法官判处阿桑奇在狱中服刑期满,他已重获自由并将返回澳大利亚。)
近期,湖北电信的部分宽带用户遭遇了苹果设备功能异常,包括iMessage、FaceTime、Apple TV屏幕镜像、HomePod使用受限及连续互通功能失效。起初,人们怀疑是苹果设备的问题,但随着网上讨论增多,发现受影响的用户主要集中在特定的宽带运营商服务范围内。经分析,宽带服务商屏蔽了identity.apple.com域名,导致设备无法正常验证Apple ID状态,进而影响功能使用。
使用在线路由追踪验证了湖北电信和联通的线路,发现联通线路能正常与苹果服务器通信,而电信则在本地终止。
+ ++
近期,有网友在csdn推出的gitcode中发现了自己在github上的项目,而自己并未入驻gitcode。
+经测试发现,github 上的仓库几乎都搬了过去,不过也根据关键词屏蔽了一些仓库。
比较有趣的是,可能csdn没有设置vpn相关的屏蔽词,因此上面有许多的vpn教程仓库,甚至有许多敏感话题的仓库.
大家可以试试搜搜,看看自己的github有没有被搬运。
+++随后由于热度较高,目前GitCode无法正常访问,ITdog测速全红;然后又被V友爆料对敏感仓库进行的是前端屏蔽,可谓抽象.
+
++2024-06-24 17:37 by RIP
+
Linux 资深网络开发者 Larry Finger 于 6 月 21 日去世,享年 84 岁。他的妻子在 linux-wireless 邮件列表上通过了一份简短声明发布了他去世的消息。Larry Finger 自 2005 年起参与 Linux 内核无线驱动的开发,近二十年来向主线内核贡献了逾 1500 个补丁。最初是博通的 BCM43XX 驱动,近期则是 RTW88、RTW89、R8188EU、R8712、RTLWIFI、B43 等内核网络驱动。部分是由于他的贡献,Linux 无线硬件支持过去二十年取得了长足进步。
缅甸军政府从 5 月 30 日起开始屏蔽 VPN 使用,如赛风和NordVPN等。军政府还让士兵随机检查行人的手机,寻找是否安装了非法 VPN 应用。报道称,有城市居民因为安装了 VPN 应用被罚款 300 万缅元(1380 美元),如果付不起钱则会遭到逮捕。知情人士称,军政府雇佣了一家中国公司实现 VPN 屏蔽,屏蔽使用了来自中国的软件。Access Now 的亚太政策分析师 Wai Phyo Myint 表示,军政府过去三年一直在寻找最新技术和工具加强对信息访问的控制,最新禁令是至今最严厉的互联网访问限制。
从6月22日开始多名网友收到京东商城发来的通知短信,在短信中京东称监测到用户账号可能被恶意使用,如果用户使用第三方比价工具或插件则必须卸载并修改京东账号密码,否则账号将被持续进行限制。
目前电商网站类的比价工具、扩展程序乃至使用脚本进行嵌入式比价的非常多,京东此番操作将会影响不少用户,逼迫用户停止使用此类软件。
+++另附:中国“618”购物节销售额首次下降
+
随着中国电商平台竞相提供全年大幅折扣,中国的网络购物节正开始失去光彩。根据数据公司 Syntun 的报告,在周四结束的“618”购物节期间,全网销售总额同比下降7%,至7430亿元人民币。研究公司 Feigua 的数据显示,5月下半月,中国“直播带货一哥”李佳琦的销售额同比下降46%,美妆主播骆王宇的销售额暴跌了68%……。
思源字体背后的中国公司- 造福亿万国人,默默无闻 40 载,让中国字体走向世界
+做好优化、选好软件,改善 Android 类原生 ROM 的使用体验
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.
+日本数字厅大臣河野在上月的发布会表示:“在 1,034 项法规中,我们已经完成了对 1,033 项要求通过软盘提交的法规的审查”,法规关于软盘的使用已全部废除。河野大臣表示,接下来还会推动废除传真机办公。
SSH RCE: CVE-2024-638该漏洞是由于 OpenSSH 服务器 (sshd) 中的信号处理程序竞争问题,未经身份验证的攻击者可以利用此漏洞在 Linux 系统上以 root 身份执行任意代码。
影响版本:8.5p1 <= OpenSSH < 9.8p1
在我们的实验中,平均需要约 10,000 次尝试才能赢得这种竞争条件,因此每 120 秒 (LoginGraceTime) 接受 100 个连接 (MaxStartups) 需要约 3-4 小时。最终,平均需要约 6-8 小时才能获得远程 root shell,因为我们只有一半的时间可以正确猜出 glibc 的地址(由于 ASLR)。
++目前几个发行版的动静:
+
Android 系统里存在设备名称这个配置,它会作为蓝牙、Wi-Fi 热点网络共享的默认名称,展示给其他设备。并且会作为环境变量 Settings.Global.DEVICE_NAME,能被 App 读取。
2024年6月 下旬,真我(realme)手机在系统更新日志中提到:
+++新增 更改手机名称联网校验功能,系统会检测手机名称是否存在敏感字符,校验未通过将无法保存或使用更改的手机名称
+
根据 V2EX 上的讨论来看,小米手机也被添加了此限制。而造成此审查的直接原因,可能与限制 AirDrop 相同,都是在尝试管理「近距离自组网」
关于使用 Wi-Fi 名称来抗议,在俄罗斯存在类似的先例:2024年3月,一名学生将路由器的名称设置为:Slava Ukraini!(荣耀属于乌克兰!),如果有人在范围里检查 Wi-Fi 选项,就会看到这段口号。随后该学生在莫斯科被捕,法院以展示「极端主义组织标志」的罪名,判处其 10 天监禁,该学生随后还被莫斯科国立大学开除。
使用包含"bot"或"spider"的UA访问知乎时,页面的部分内容被替换为随机汉字
+知乎在 robots.txt 中移除 Google 和 Bing 等搜索引擎后,近期又针对UA进行了严格的限制。目前,在 User Agent 中出现"bot"或"spider"的访问结果中,知乎会将问题或专栏的标题、发布者的用户名、文章正文等文本替换为随机汉字。必应的部分搜索结果已经受到了影响。
此外,与 CentOS 7 同源的红帽企业 Linux 7(RHEL 7)也于今日进入 EOM 停止维护阶段,企业可通过 ELS 订阅付费获得额外 4 年的延长支持。
据介绍,CentOS 项目与红帽已于 2020 年结束 CentOS Linux 开发,将全部投资转向 CentOS Stream:
在 RHEL 新版本发布之前,红帽会在 CentOS Stream 上持续发布源代码,作为 RHEL 的上游开源开发平台
CentOS 创始人 Gregory Kurtzer 启动 Rocky Linux 项目,开发 RHEL 的下游二进制兼容版本
据亚马逊中国官网消息,2024年6月30日起,Kindle中国电子书店停止云端下载服务,此后未下载的电子书将无法下载和阅读。同时,Kindle客户服务也将停止支持。
Kindle中国电子书店已于2023年6月30日停止运营。亚马逊建议用户及时将已购买电子书及其他Kindle内容下载至Kindle阅读器和Kindle App (含手机端和电脑端).
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.
+谷歌在Chromium开源项目中预留了私有API,允许谷歌网站读取PC的CPU/GPU使用率、内存使用率等硬件信息。这些API仅对谷歌主域名开放,可能违反了欧盟的数字市场法案(DMA),并可能构成不公平竞争。例如,Google Meet可以利用这些信息优化视频会议性能,而竞争对手如Zoom则无法获取同样级别的硬件信息。
此外,这些API通过一个Chrome扩展程序实现,用户无法禁用或在扩展管理页面中找到。Microsoft Edge和Brave浏览器也被发现内置了该扩展程序。目前尚不清楚谷歌是否会更新Chrome以允许用户禁用此扩展。
据V2EX站友表示,插件远比网页的级别高,可调用资源甚至接近浏览器的级别,可用来收集用户的硬件画像,对保护隐私极其不利。
+厦门五五安科信息科技有限公司的昆仑解锁实验室最近发布了一款面向Android 14的提权取证工具。此工具据推测通过利用漏洞绕过了Android权限管理机制,从而访问和提升设备权限,实现对设备的深入取证。特别值得注意的是,该工具成功实现了对采用Google Tensor芯片的Pixel手机的权限提升。据悉,此漏洞可能已由Google在其七月份的安全更新中得到修复,然而目前尚不明确该取证工具是利用已知漏洞还是未公开的新漏洞进行提权。鉴于此,建议所有用户更新至最新的安全补丁,以确保设备安全。
工信部办公厅、网信办秘书局近日发布《关于开展“网络去 NAT”专项工作,进一步深化 IPv6 部署应用的通知》。
+增加 IPv6 互联网专线产品供给,新增互联网专线默认开通 IPv6 功能。要加快实施家庭网关 IPv6 地址前缀二次分发功能升级。固定宽带用户 IPv6 连通率不低于 80%。终端设备制造企业要严格落实无线电发射设备型号核准有关通知要求。各省(区、市)有关部门要推动属地终端设备制造企业加快存量家庭无线路由器 IPv6 功能升级。注册、登录、使用全链条支持 IPv6,提升固网环境下 IPv6 流量占比。推动边缘节点、核心节点等各层级支持 IPv6,提升用户加速、业务调度和内容回源等 IPv6 流量占比。云服务企业要优化产品业务逻辑,向用户提供服务时默认启用 IPv6 功能。+ ++
近日,知名官改 ROM Xiaomi.EU 的测试者 Kacper Skrzypek 在 X 发文[1]称,小米在开机向导中添加了区域检测机制。
如果设备硬件为国行版,但正在运行国际系统,将无法完成开机向导,并提示「Unsupported software」。
原推文提醒,该机制目前已在 Redmi Note 13 系列实装。
+工业和信息化部7月10日向中国电信、中国移动、中国联通颁发许可,批复在广西南宁、山东青岛、云南昆明、海南海口设立国际通信业务出入口局。
1994年,我国全功能接入国际互联网,中国电信、中国移动、中国联通在北京、上海、广州设立了9个国际通信业务出入口局,实现公众互联网与国际互联网连通。
广西南宁、山东青岛、云南昆明、海南海口新增设6个国际通信业务出入口局,这是30年来首次增设,建成后将显著提升国际网络通信能力,更好推动基础设施互联互通、数据跨境流动和国际数字贸易发展,促进更高水平开放,为构建新发展格局塑造新动能新优势。
目前已知的登陆站应该是青岛、汕头、上海,以及福州的淡福海缆, 似乎是湾专线、以及通信业务才用的,还有厦金海缆,不过这些都不给宽带业务用。
爱宠死了但我仍在偿还狗狗的医疗费用动物医疗会成为下一个吸血产业吗
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.
+NVIDIA 于 2022 年 5 月发布了一组 Linux GPU 内核模块,作为具有双重 GPL 和 MIT 许可的开源模块。当时该公司宣布,NVIDIA 开放内核模块最终将取代闭源驱动程序。现在,由于开源 GPU 内核模块实现了同等甚至更好的应用程序性能,NVIDIA 将在即将发布的 R560 驱动程序版本中完全过渡到开源 GPU 内核模块。
对于 Grace Hopper 或 Blackwell 等最新平台,用户必须使用开源 GPU 内核模块,这些平台不支持专有驱动程序。对于 Turing、Ampere、Ada Lovelace 或 Hopper 架构的较新 GPU,NVIDIA 建议切换到开源 GPU 内核模块。对于 Maxwell、Pascal 或 Volta 架构的较旧 GPU,开源 GPU 内核模块与平台不兼容,将继续使用 NVIDIA 专有驱动程序。
GitLab 于 2021 年在美股上市,现在的股价不到上市时的一半,仅 2024 年就下跌了 16%。
尽管该公司报告称,其收入同比增长 33%,达到 1.692 亿美元,并在最新季度首次实现正现金流,但它承认,由于与微软旗下github的竞争,其产品定价面临阻力。
+根据 GitLab 国内官网介绍,许多知名企业均有使用该公司服务,包括中国联通、中国电信、英特尔、网易、理想、蔚来等。
今年以来,国家推动新一轮家电以旧换新,引导完善废旧家电回收体系。不过,私拆、翻新机目前仍然大量存在,翻新机已是业内公开的秘密,它存在一条隐形的产业链。不久前格力电器董事长兼总裁董明珠在格力电器股东大会上说,有的废旧空调,被不良商家几百元收回来,翻新后1500元卖出去,消费者是最大的受害者。
今年以来,浙江省气象局基于省突发事件预警信息发布系统对接“闪信”发布渠道,针对三家运营商“霸屏”业务要求的区别,实现快速自动编辑、一键式推送发布功能。在发布气象预警信息时,“闪信”还可与浙政钉信息、短信、应急广播信息等原有渠道一并通过该系统一键发布。
++PS:0级短信早该用来预警了,有些地方却用来发广告;而且这种事居然没有全国统一...
+
终于可以在 Linux 下愉快打印了:Linux 发行版配置打印机攻略
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章,每周四更新.PS:因为昨天输入法突发恶疾,所以无法按时更新。
+瑞士通过了名为《联邦电子政务法》(EMBAG)的立法,强制要求所有公共部门使用 开源 软件 (OSS)。 该法律规定,除非涉及第三方权利或安全问题,否则所有公共机构必须公开其开发或为其开发的软件的源代码。这一举措旨在提高政府运营的透明度、安全性,和效率。
+360 在测试新功能名为 AI 弹窗过滤器,可以拦截用户电脑上包括但不限于360 自家的弹窗广告。
+原来的360弹窗过滤器无法过滤360自家的弹窗广告。此功能包含在360AI大会员中,30元每月。
+并且暂时还不清楚能否彻底拦截 360 全家桶的所有弹窗广告。
+有大量网友在微博、X、reddit等社交媒体上反馈自己工作的 Windows 电脑出现蓝屏,疑似因为 CrowdStrike 的 csagent.sys 导致的。
+从零开始搭建你的免费博客评论系统(Remark42 + fly.io)
+ + + +前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+中国发布《国家网络身份认证公共服务管理办法》征求意见稿。截至日期8月25日。办法中提到,自然人在互联网服务中依法需要登记、核验真实身份信息时,可通过国家网络身份认证 App 自愿申领并使用“网号”“网证”进行非明文登记、核验,无需向互联网平台等提供明文个人身份信息。由此,可以最大限度减少互联网平台以落实“实名制”为由超范围采集、留存公民个人信息。不满十四周岁的自然人需要申领网号、网证的,应当征得其父母或者其他监护人同意。互联网平台不得要求用户另行提供明文身份信息。
+记者注意到,申领和使用“网号”“网证”的应用“国家网络身份认证App(认证版)”已在多个应用商店上线。此前,中国公安部、网信办等研究起草了征求意见稿,核心是“为自然人提供申领网号、网证以及进行身份核验等服务。”根据反馈,申领注册“网号”“网证”需要使用身份证,人脸识别是否为本人,关联手机号,设置网络身份口令,授权网络身份在用户手机使用。目前,正处于试点阶段,已上线试点APP和场景共67个,如国家政务服务平台、中国铁路12306、淘宝、微信、小红书、QQ等。据悉,后续,有关主管部门还将继续研究适用的应用场景,包括互联网用户账号实名注册、登录,对存在涉诈异常账号的用户身份重新进行核验,网上办理政务服务事项时的身份核验等。
+++乍一看似乎还行,然后就想到根据网号一键封禁所有账号的操作,以及新的拖库危机
+
中国地震台网中心、中央广播电视总台国家应急广播与腾讯合作,推出了全国微信预警服务的公测版本。该小程序与此前江苏地震预警服务UI完全一致,自行选择即可。
+可通过微信搜索"中国地震台网"或"地震预警",进入小程序并开启服务,接收官方地震预警信息。小程序支持高并发量用户秒级消息推送,并在地震发生时提供强提醒警示及防震指南。
+++PS:依然是先试点再推广的流程,不过说好的0级短信呢。。。
+
印尼通信部周五表示,已禁止以隐私为导向的搜索引擎 DuckDuckGo,理由是担心它可能被用来访问该国非法的色情和在线赌博网站。印尼是全球穆斯林人口最多的国家,该国制定了严格的规定,禁止在网上分享被视为淫秽的内容。通信部官员乌斯曼·坎松告诉路透社,DuckDuckGo 被屏蔽“是因为很多人投诉其搜索结果中充斥着网络赌博和色情内容”。印尼近几个月来誓言要严厉打击网络赌博,并禁止访问多个此类网站。尽管网络赌博属于非法,但政府数据显示,去年有300万印尼人上网赌博,花费约200亿美元,约占国内生产总值的1.5%。
+++群友:建议安装反诈APP,最好使用鸿蒙系统内置
+
数字证书颁发机构 DigiCert 在 7 月 29 日通过博客宣布将吊销没有适当域控制验证 (DCV) 的证书,大约 0.4% 的 DigiCert 适用域验证受到影响,数量可能超过数千份。根据严格的 CABF 规则,域验证中存在问题的证书必须在 24 小时内撤销,无一例外。DigiCert 已通知受影响的客户,他们必须在 24 小时内更换证书。
+本次事件涉及通过添加 DNS CNAME 记录,并为此提供随机值进行域名控制验证。其中一种方法要求随机值以下划线字符为前缀,下划线前缀可确保随机值不会与使用相同随机值的实际域名发生冲突。最近,DigiCert 发现在某些基于 CNAME 的验证案例中使用的随机值中没有包含下划线前缀。虽然域名发生冲突的可能性实际上可以忽略不计,但如果验证不包含下划线前缀,则仍被视为不合规。DigiCert 表示,“CABF 认为任何与域验证有关的问题都是严重问题,需要立即采取行动。”
+拆解报告:DELTA台达HVP系列高压直流电源DPR240/50A整流模块
+【瞭望】海航重整案——亚洲规模最大、最难、最复杂的重整案件是如何炼成的
+前言 这里是Dich的周刊,通过博客的形式讲述每周互联网形势,以及分享一些文章。
+运营 .COM 的域名注册局威瑞信将于9月1日将批发价从9.59美元提高到10.26美元。大多数域名注册商都会在此基础上加价,但有些注册商会向客户收取批发价。因此,许多注册商都会提高价格。这是 .COM 域名价格连续第四年上涨7%,这是威瑞信与互联网名称与数字地址分配机构签订的合同以及与美国政府达成协议允许的最高涨价幅度。总而言之,自四年前以来,威瑞信已将 .COM 域名批发成本提高了31%。对于域名注册者来说,好消息是威瑞信未来两年内不得涨价。但此后该公司可以连续四年每年涨价7%。
+微软的 Microsoft Authenticator 身份验证应用存在设计缺陷,用户在扫描QR码添加新账号后,应用会覆盖之前的账号,导致多重身份验证(MFA)被锁定。
+这个问题的核心在于,Microsoft Authenticator 会用相同的用户名覆盖账户。由于多数用户的用户名是电子邮件地址,这个问题尤为严重。
+而Google Authenticator等应用通过添加银行、汽车公司等信息来避免此问题。覆盖账号后,系统难以识别哪个账号被覆盖,可能导致新旧账号均出现验证问题。用户可能在几周或几个月后才发现账号被注销。
+马来西亚互联网服务提供商 (ISP) 似乎实施了透明 DNS 代理,即强制所有互联网流量返回到其本地 DNS,即使使用谷歌和 Cloudflare 等替代 DNS 也是如此。实施该策略的 ISP 包括 Time、Maxis、U Mobile、CelcomDigi 和 Unifi。通过透明 DNS 代理,ISP 可以拦截并重定向 DNS 请求至本地 DNS。
+为了遵守规定,所有电信公司/互联网服务提供商都必须通过其本地 DNS 阻止被认定为违法的网站。目前尚不清楚这项针对本地服务的透明 DNS 代理实施时间,但由于已有四家以上的电信公司实施,因此这似乎是针对所有电信公司的全国性指令。据称该指令早在今年2月就已发布。 马来西亚监管机构尚未对此有关的询问作出回应。
+—— SoyaCincau、Sinarprojec
+知名密码管理器1Password的Mac版本被发现存在一个高危安全漏洞,该漏洞允许恶意软件绕过进程间的通信保护,窃取用户的解锁密钥。
+这一安全问题由参与DEFCON黑客大赛的安全研究人员发现,并计划在一次演讲中公开。1Password已经收到通知并及时修复了这一漏洞,敦促用户升级到8.10.38或之后的版本以确保安全。
+该漏洞被标识为CVE-2024-42219,目前没有证据表明它已被恶意黑客利用,更多关于该漏洞的细节将在DEFCON大会上演讲后公布。
+前言 由于厂商默认安装windows家庭版导致各种问题频发,这里对 widnows 安装做一个总结,以及附上我个人的windows配置。
+安装Windows有两种情况:1.在一台全新的电脑上安装;2.想为现有的系统更换版本。本文主要介绍这两种情况。如果只想对现有的系统进行优化,推荐看下一篇的"Windows系列(2):常用操作与配置".
全新安装
+为现有系统更换版本
+本地升级或外部升级;PS:
++++
本地升级:即为不需要外部启动盘,不动你的任何东西的无损安装;但需要一些前提条件;
+++
外部升级:即为外部启动盘安装系统,可以格式化全盘全新安装;也可以保留数据安装,会将你的的数据放在C盘的windows.old文件夹。
++数据安全:不管是本地还是外部升级,除非你格式化全盘重新安装,否则安装只会动C盘,其他分区的数据(如D盘等)不会触碰,可放心;
+
不管你是哪一种情况,都推荐你先下载ISO镜像,因为ISO镜像方法是最通用,最常用的。
+Dichos镜像,是笔者个人制作的镜像,参考乱七八糟:Windows封装与全自动安装;
+PS:
+++镜像大小从1G~8G左右不等,因为有的不知道哪来的镜像里面版本不全,我们要下载的是包括所有主流版本的ISO,即为里面包括家庭版教育版专业版等等。如果你从其他地方下载ISO镜像,里面可能会捆绑流氓软件甚至有病毒。
+
++我们要使用的是
+23H2专业工作站版本,性能最强,功能最全面,适合日常使用和开发;笔记本自带的往往是24H2家庭中文版,bug多功能少,不建议使用。
++以上说的是功能版本,还有大版本的区别,目前暂时用不上,详细可以看本系列第三篇
+Windows系列(3):分类与激活.
在远古年代你可能看过电脑城老板使用Ghost安装系统,近一点的使用诸如“大白菜”,“老毛桃”以及各种PE安装系统,这是比较旧式的方法。
+本文推荐使用Ventoy启动盘+windows镜像的方法安装Windows,好处在于:
+在官网下载Ventoylanguage中改为中文显示,可以看到左上角有配置选项GPT,开启安全启动支持;分区格式设置为NTFS;分区设置中进行分区,选择在磁盘后保留一段空间,这里的空间将不被分区,即为空闲空间,可以稍后建立分区当作普通的文件存储盘;U盘总容量-保留空间-ventoy保留分区的空间新建一个盘,这里可以放ISO、WIM、IMG、VHD(x)、EFI等等选择磁盘并开始安装,过一会儿即可安装完成。不管你使用哪种方法都建议做好这一步骤:
+关闭Bitclocker:打开设置,进入隐私与安全→ 设备加密,将其状态切换为关闭。系统会弹窗提示确认,点击关闭,系统将开始解密。解密过程中需要比较久的时间,解密完成后即可成功。
关闭安全启动和Intel VMD:查找你的笔记本的BIOS 进入键,一般为F2;在开机的时候一直按按按BIOS 进入键,即可进入BIOS/UEFI。在其中查找安全启动(Secure Boot)和Intel VMD(如果有)并将它们关闭(disable),随后按保存退出键(一般为F10或F12)。
确保C盘有足够的空间:重新进入BIOS,在其中的引导选项中选择USB设备(你的启动盘的设备名),将其调到第一个,然后保存退出;重新启动,这时候就会进入Ventoy的界面,可以看到我们放进去的两个ISO,我们直接选择HotPE进入并使用里面的Diskgenius,把其他盘的空间分给C盘一点点,使其有至少9GB可以使用。
PS:
+++无论你用什么方法都建议先备份好数据!!!
+
++无损升级是有前提条件的!!!除了前面说的环境准备,还需要ISO镜像比原来的系统更新,比如23H2的镜像往往就不能无损更新24H2的系统,只能选择外部升级;
+
++如果你选择预安装密钥的方法往往比较容易无损升级,但这样就不能使用Dichos的优化,需要手动优化。
+
如果你没有购买正版Windows,上文安装的系统可以使用MAS脚本或者HEU_KMS工具来激活.
+++如果你使用Dichos,可以直接跳到三.驱动级开始.
+
++ +常用的优化软件:
+
驱动的安装没有集成在Dichos中,而是作为手动安装的一部分避免出错。如自带系统有驱动包,先进系统拿出然后再安装新系统;一般来说,包括:
+而根据来源,又可以分为公版/通用驱动和笔记本厂商特调/专用驱动,一般而言装公版驱动即可,保持通用性;如果你是重度游戏玩家则可以考虑特调驱动。
常用驱动下载网站:
+| 分类 | 名称 | 下载 |
|---|---|---|
| 综合 | 驱动天空 | 链接 |
| 厂商 | 吾空 | 链接 |
| 厂商 | 华硕 | 链接 |
| 厂商 | 联想 | 链接 |
| 三大件 | AMD | 链接 |
| 三大件 | Intel | 链接 |
| 三大件 | NVIDIA | 链接 |
使用开源软件!
++Rime输入法在Windows端叫小狼毫,输入方案用的是雾凇拼音 ,在
+获取更多输入方案中命令行输入iDvel/rime-ice:others/recipes/full安装。
常用测试软件
+CPU-Z +GPU-Z +AIDA64 +Diskinfo +Furmark +Afterburner
+Done.
+ +前言 Windows操作系统作为全球最为普及的桌面操作系统之一,其用户界面的设计非常经典,但存在许多不足之处,本篇记录一些常用脚本。
+开机之前,先断网,然后输入Shift+F10,会弹出命令行界面,并输入
+bash oobe\BypassNRO.cmd:
+回车之后会重启,之后就可以跳过联网了,选择
+bash I don't have internet
+即可。
++微软在 Windows 11 最新版中删除了 BypassNRO 脚本,以下是最新方法:
+
在 Windows 11 OOBE 登录用户账户界面按 Shift+F10 打开命令提示符 (CMD)
+在命令提示符窗口中输入命令start ms-cxh:localonly按回车
此时系统将自动打开微软账户管理的窗口,在这里可以输入用户名称;在这里输入用户名和密码后继续即可,此时不再需要 BypassNRO 脚本或注册表
+需要注意的是目前该命令仅适用于 Windows 11 家庭版和专业版系列 (包括专业版、专业工作站版和专业教育版)。
+这里使用MAS的脚本:
+irm https://get.activated.win | iex
+
+1.按Win+I打开Windows设置页面。
+2.单击“更新和安全”>“Windows更新”,然后在右侧详情页中选择“暂停更新7天”选项即可在此后7天内关闭Windows更新。
+3.然后就可以使用脚本彻底关闭更新:将以下命令保存为.bat文件,运行即可。
+::Windows auomatic updates
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU /v AutoInstallMinorUpdates /t REG_DWORD /d 1 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU /v NoAutoUpdate /t REG_DWORD /d 1 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU /v AUOptions /t REG_DWORD /d 4 /f
+reg add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update" /v AUOptions /t REG_DWORD /d 4 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate /v DisableWindowsUpdateAccess /t REG_DWORD /d 0 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate /v ElevateNonAdmins /t REG_DWORD /d 0 /f
+reg add HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Explorer /v NoWindowsUpdate /t REG_DWORD /d 1 /f
+reg add "HKLM\SYSTEM\Internet Communication Management\Internet Communication" /v DisableWindowsUpdateAccess /t REG_DWORD /d 0 /f
+reg add HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\WindowsUpdate /v DisableWindowsUpdateAccess /t REG_DWORD /d 0 /f
+sc stop wuauserv
+sc config wuauserv start=disabled
+sc stop WaaSMedicSvc
+sc config WaaSMedicSvc start=disabled
+reg add HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\InstallService\State /v AutoUpdateLastSuccessTime /t REG_SZ /d "2100-01-01T00:00:00+08:00" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseFeatureUpdatesStartTime /t REG_SZ /d "2100-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseQualityUpdatesStartTime /t REG_SZ /d "2100-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseUpdatesExpiryTime /t REG_SZ /d "2100-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseFeatureUpdatesEndTime /t REG_SZ /d "2100-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseQualityUpdatesEndTime /t REG_SZ /d "2100-01-01T00:00:00Z" /f
+
+如果要恢复更新,使用以下命令,同样保存为.bat运行:
+::Windows auomatic updates
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU /v AutoInstallMinorUpdates /t REG_DWORD /d 0 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU /v NoAutoUpdate /t REG_DWORD /d 0 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU /v AUOptions /t REG_DWORD /d 0 /f
+reg add "HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\Auto Update" /v AUOptions /t REG_DWORD /d 4 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate /v DisableWindowsUpdateAccess /t REG_DWORD /d 1 /f
+reg add HKLM\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate /v ElevateNonAdmins /t REG_DWORD /d 1 /f
+reg add HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\Explorer /v NoWindowsUpdate /t REG_DWORD /d 0 /f
+reg add "HKLM\SYSTEM\Internet Communication Management\Internet Communication" /v DisableWindowsUpdateAccess /t REG_DWORD /d 1 /f
+reg add HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\WindowsUpdate /v DisableWindowsUpdateAccess /t REG_DWORD /d 1 /f
+sc config wuauserv start=auto
+sc start wuauserv
+sc config WaaSMedicSvc start=auto
+sc start WaaSMedicSvc
+reg add HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\InstallService\State /v AutoUpdateLastSuccessTime /t REG_SZ /d "2000-01-01T00:00:00+08:00" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseFeatureUpdatesStartTime /t REG_SZ /d "2000-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseQualityUpdatesStartTime /t REG_SZ /d "2000-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseUpdatesExpiryTime /t REG_SZ /d "2000-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseFeatureUpdatesEndTime /t REG_SZ /d "2000-01-01T00:00:00Z" /f
+reg add HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings /v PauseQualityUpdatesEndTime /t REG_SZ /d "2000-01-01T00:00:00Z" /f
+pause
+
+Win11的显示更多选项的二级菜单过于繁琐,怎么设置才能将其关闭,并恢复成Win10的状态呢?
步骤1. 按Win+S打开搜索框,输入cmd并以管理员身份运行命令提示符。
+步骤2. 输入以下命令并按Enter键执行。
+reg add HKCU\Software\Classes\CLSID{86ca1aa0-34aa-4e8b-a509-50c905bae2a2}\InprocServer32 /ve /d “” /f
+
+或者
+reg add "HKCU\Software\Classes\CLSID\{86ca1aa0-34aa-4e8b-a509-50c905bae2a2}\InprocServer32" /f /ve
+taskkill /f /im explorer.exe
+start explorer.exe
+
+如果想要重新打开Win11新样式的右键菜单的话,以同样的方式在命令提示符中执行此命令:
+reg delete "HKCU\Software\Classes\CLSID{86ca1aa0-34aa-4e8b-a509-50c905bae2a2}" /f
+
+Windows Defender具有防篡改保护,因此需要先在设置-安全中心-设备保护中将实时防护关闭,然后在组策略或者注册表中将其禁用。
Windows + R快捷键打开「运行」对话框,执行regedit打开注册表编辑器。HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows Defender
+
+DisableAntiSpyware的 DWORD (32位) 值设置为1,如果没有就新建。++也可以使用defendnot
+
选择“开始”按钮 ,然后滚动查找你希望在启动时运行的应用。
+右键单击该应用,选择“更多”,然后选择“打开文件位置”。此操作会打开保存应用快捷方式的位置。如果没有“打开文件位置”选项,这意味着该应用无法在启动时运行。
+文件位置打开后,按win+ R,键入“shell:startup”然后选择“确定”。这将打开“启动”文件夹。
将该应用的快捷方式从文件位置复制并粘贴到“启动”文件夹中,即添加启动项成功。
右键点击任务栏上的时间,选择 "调整日期/时间"。在日期和时间窗口中,点击互联网时间标签。点击 "更改设置…" 按钮。在弹出的对话框中,勾选同步时钟与 Internet 时间服务器,然后在 "服务器" 输入框中填写你想要的时间服务器,例如:
time.windows.com(微软默认服务器)
+time.nist.gov(美国国家标准技术研究院的时间服务器)
+pool.ntp.org(一个公共的 NTP 时间服务器池)
+
+应用更改:点击 "更新现在",然后 "确定" 保存设置。
+# 在 Windows 中以管理员权限运行命令提示符,执行:
+reg add "HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\TimeZoneInformation" /v RealTimeIsUniversal /t REG_DWORD /d 1 /f
+
+Get-NetIPInterface
+
+你会看到类似:
+IfIndex InterfaceMetric InterfaceAlias
+------- -------------- --------------
+15 25 Wi-Fi
+3 15 以太网
+
+# InterfaceMetric 值越小,优先级越高。
+
+将有线网络(以太网) 设为更高优先级(值更小):
+Set-NetIPInterface -InterfaceIndex 3 -InterfaceMetric 10
+
+Set-NetIPInterface -InterfaceIndex 15 -InterfaceMetric 25
+
+Restart-NetAdapter -Name "以太网"
+
+这样,当网线插入时,Windows 会优先使用有线网络;断开网线后,自动切换到 WiFi。
+Win + R 输入 regedit 打开注册表编辑器,进入路径:
+HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\Interfaces
+
+在 Interfaces 里找到你的有线网卡和无线网卡(可以根据 IP 或 MAC 地址确认)。
+有线网卡(Ethernet):设为 10
+无线网卡(WiFi):设为 25
+
+重启电脑生效。
+++保存为.bat格式
+
@echo off
+REM 清理代理设置
+REG DELETE "HKCU\Software\Microsoft\Windows\CurrentVersion\Internet Settings" /v ProxyEnable /f
+REG DELETE "HKCU\Software\Microsoft\Windows\CurrentVersion\Internet Settings" /v ProxyServer /f
+echo 代理设置已清除
+
+++保存为.reg格式
+
开启3D加速
+Windows Registry Editor Version 5.00
+[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\DirectDraw]
+"EmulationOnly"=dword:00000000
+[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Direct3D\Drivers]
+"SoftwareOnly"=dword:00000000
+[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\DirectDraw]
+"EmulationOnly"=dword:00000000
+[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Direct3D\Drivers]
+"SoftwareOnly"=dword:00000000
+
+关闭3D加速
+Windows Registry Editor Version 5.00
+[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\DirectDraw]
+"EmulationOnly"=dword:00000001
+[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Direct3D\Drivers]
+"SoftwareOnly"=dword:00000001
+[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\DirectDraw]
+"EmulationOnly"=dword:00000001
+[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Direct3D\Drivers]
+"SoftwareOnly"=dword:00000001
+
+Done.
+ +前言 Windows的正版售价十分昂贵,2025年的今天大部分人都使用着OEM厂商自带的windows系统或自己想办法激活,那么,激活到底是什么原理?
+一般情况下,提到Windows和Office的版本,是按功能分类的,如:
+在按功能划分的基础上,根据销售渠道又细分出以下几种不同版本,激活方式与之对应,激活原理也各不相同:
+大版本分类
+| 分类 | 消费者版(Consumer) | 商务版(Business) | 物联网版(IoT) | 长期服务版(LTSC) |
|---|---|---|---|---|
| 目标用户 | 家庭用户、个人消费者 | 企业、机构、教育用户 | 嵌入式设备、工业控制、POS、医疗设备等 | 关键任务系统、长期稳定运行的设备 |
| 主要版本 | Windows Home、Home Single Language、Education | Windows Professional、Enterprise、Education | Windows IoT Core、IoT Enterprise、IoT Enterprise LTSC | Windows Enterprise LTSC、IoT Enterprise LTSC |
| 预装应用 | 包含 Microsoft Store、娱乐和社交类应用 | 精简部分消费类应用,保留企业管理工具 | 极度精简,移除大部分消费类应用 | 移除 Microsoft Store、Cortana 等非必要功能 |
| 更新策略 | 定期推送功能和安全更新 | 可由企业控制更新策略,支持延迟功能更新 | 可选择常规更新或 LTSC 版本,更新策略灵活 | 仅推送安全补丁和关键修复,无新功能更新 |
| 支持周期 | 通常为 18 个月 | 通常为 18~30 个月,取决于版本和配置 | IoT Enterprise LTSC 支持周期可达 10~15 年 | 通常为 5 年主流支持 + 5 年扩展支持,共 10 年 |
| 授权方式 | 零售授权,需在线激活 | 批量许可(Volume Licensing)、OEM 授权 | OEM 授权,适用于特定硬件设备 | 批量许可,适用于特定行业和关键任务设备 |
| 适用场景 | 日常办公、娱乐、学习 | 企业办公、教育机构、专业工作站 | 工业自动化、零售终端、医疗设备等嵌入式系统 | 医疗设备、金融终端、工业控制系统等需长期稳定运行的环境 |
零售版 Windows 和 Office 的激活机制可以通俗地类比为在商店购买记事本:用户支付费用获得记事本,如何使用由用户决定。
+试用期与激活码输入
+安装零售版后,系统会有一段试用期。用户需进入激活界面,输入零售版激活码。激活组件会验证激活码的正确性,并根据激活码和硬件信息生成 Installation ID(IID)。
激活方式
+服务器记录与限制
+微软服务器会记录硬件信息和激活码信息。如果激活码使用次数过多,可能被限制为仅电话激活;若激活的电脑数量超标,则激活码会被封禁,无法再使用。尽管微软封禁激活码,但违规泄露的新激活码常被二手商以低价出售。
激活机制的技术特性
+零售版激活依赖微软服务器的校验,采用不对称加密技术:公钥在系统中,私钥在服务器上。用户只能校验 CID,无法从 IID 计算 CID。这使得激活必须经过服务器验证。
盗版激活手段
+VOL版有两种激活方式:一种是MAK激活(Multiple Activation Key),另一种是KMS激活(Key Management Service)。
+MAK激活流程: MAK激活的流程类似于零售版,但激活码属性有所不同。每个 MAK 激活码预设了有限的可用次数,可以用于激活任意数量的电脑。
+特点:
+KMS激活流程: KMS 激活通过本地搭建的激活服务器实现,适合需要批量激活的企业或大规模组织。
+特点:
+++没有花钱购买微软授权,擅自使用KMS激活仍是盗版,个人使用微软懒得管,企业这么搞会吃官司。
+
++弊端就是:必须每180天再激活一次;成功激活后,你的电脑就会变成团队电脑。KMS工具开发者就是管理员。不要不以为然,管理员能够执行的操作权限非常高,拷贝个数据收集个信息简直是小菜一碟,更厉害的还能直接reset你的系统而保留KMS的权限。说不定,哪天KMS的开发者不开心,就帮你清空一下电脑。
+
OEM激活(Original Equipment Manufacturer)是三种激活方式中最特殊的,因为它完全脱离了联网认证,实现了高度绑定于硬件的激活机制。
+OEM激活机制:生产厂商在主板 BIOS 芯片中加入 SLIC 信息(Software Licensing Internal Code),同时在操作系统中预装对应的厂商证书和一个 OEM 激活码。
+特点:
+破解与改装方法:由于 OEM 激活省略了联网步骤,激活逻辑被高度依赖硬件信息,这也给破解提供了多个切入点:
+硬改流
+直接刷写主板 BIOS,将 SLIC 信息写入其中,使主板伪装成具备 OEM 激活能力的硬件。缺点:风险较高,操作不当可能损坏 BIOS,导致主板无法启动。
+暗改流
+找到内存中存储 BIOS 数据的位置,将 SLIC 信息直接注入内存。优点:无需修改主板 BIOS,操作更灵活。缺点:仅在系统运行时生效,重启或关机后需重新注入。
+破解流
+修改操作系统读取 BIOS 数据的逻辑,让系统从伪造的 SLIC 数据中完成验证。
+配合导入对应的厂商证书和 OEM 激活码,实现伪装成 OEM 激活。操作相对简单,适用于多种硬件。缺点:可能影响系统稳定性,且破解工具质量参差不齐。
+微软在 Windows 10 中推出了全新的激活方式——数字激活(Digital License Activation)。这种激活方式彻底改变了传统激活依赖激活码或联网验证的逻辑,通过绑定硬件信息和微软账户,为用户提供更加便捷的体验,同时也带来了新的破解手段。
+数字激活的原理
+特点:
+数字激活的漏洞利用
+微软为支持用户从低版本(如 Win7/Win8)升级到 Win10,引入了系统升级继承激活状态的规则,这成为数字激活漏洞的核心:如果升级前的系统已经激活,无论激活手段是否合法,升级后的 Win10 系统都会继承激活状态。即使此前是通过盗版手段激活的系统,也能顺利完成升级并绑定数字激活状态。
+关键组件:gatherosstate.exe
+数字激活的破解演变:
+手动操作版本:从 Win10 安装包中提取 gatherosstate.exe,将其放到 Win7/Win8 系统中,利用任何激活手段(如 OEM 激活或暴力破解)骗过 gatherosstate,生成 GenuineTicket.xml。在 Win10 系统中导入该文件,重启联网,即可激活系统。
+进阶版数字激活工具:集成破解的激活组件(如 slc.dll),跳过预先激活 Win7/Win8 的步骤,直接生成 GenuineTicket.xml。本质等同于暴力破解,只是流程更加自动化。
+HWID Key 的出现:经过逆向分析,发现 gatherosstate.exe 完全在本地运行,生成 HWID 的算法无需联网验证。专业人士破解并提取了生成 HWID 的算法,开发出 HWID Key 工具,能够在任意电脑上生成有效的 HWID 并完成数字激活。用户无需再通过升级路径或手动操作,随时随地实现数字激活。
+++ +最新消息,MAS团队破解了SSP,现在可以使用TSforge来激活自 Windows 7 以来每个版本的 Windows 的每个版本,以及自 Office 2013 以来的每个 Windows 插件和 Office 版本!
+
前言 由于厂商默认安装windows家庭版导致各种问题频发,这里作者封装了一个开箱即用的,全自动安装,激活和优化的Windows11镜像。
+ +Dich-OS base on zh-cn_windows_11_business_23h2
+PS:
+禁用自动更新是创建一个名为 PauseWindowsUpdate 的计划任务,一次又一次地暂停更新一周.如果要运行 Windows 更新一次,请单击 “设置”中的“恢复更新 ”.
+删除默认应用程序,但保留了记事本,照片,PowerShell,Windows Terminal ,Windows Media Player (classic) ,Calculator , Clock , Xbox Apps(游戏手柄用)
+这会创建一个计划任务,诱使 Windows 认为设备一直在使用中,即使更新也不会突然关机.
+可以将要用的软件安装包放入该文件夹中,会自动放到桌面.
+感谢以下项目:
+SHA-256:5920ca1b839c2823cad5223cdff39671784d98d18da03fa4377a362ad480ce54
+下载链接:这里
+ +前言 由于 Windows 中开发环境较 linux 复杂,这里总结 Windows 中使用 Jupyter 开发 Python 的环境配置。
+Python是一种跨平台的编程语言,社区生态丰富,有许多现成的包可以调用。传统的安装方法如下:
+但Python开发项目时往往需要不同版本,不同的第三方包,如果用传统方法难以管理;因此现在的主流方法是:
+在Anaconda官网下载并安装,安装成功后,命令行中敲conda info,会显示conda的版本和python的版本等详细信息;再敲conda list,会列出当前环境下所有安装的包。
安装好了Anaconda,就相当于同时有了Python、环境管理器、包管理器以及一大堆开箱即用的科学计算工具包。
+++linux中安装Miniconda
+
# Miniconda安装脚本
+wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh
+# 执行以下命令启动安装程序:
+bash Miniconda3-latest-Linux-x86_64.sh
+# 验证安装
+conda --version
+
+conda create --name env_name python=3.6
+
+conda create --name env_name python=3.7 numpy scrapy
+
+conda activate env_name
+
+conda deactivate env_name
+
+conda create --name new_env_name --clone old_env_name
+
+conda remove --name env_name --all
+
+conda env export > environment.yml
+
+conda env create -f environment.yml
+
+(test) ➜ ~ conda info -e
+- conda environments:
+#
+base /Volumes/300g/opt/anaconda3
+test * /Volumes/300g/opt/anaconda3/envs/test
+
+conda list
+
+conda list -n env_name
+
+conda search scrapys
+
+conda install scrapy
+
+conda install --name target_env_name package_name
+
+conda update scrapy
+
+conda update -n target_env_name package_name
+
+conda update --all
+
+conda remove scrapy
+
+conda remove -n target_env_name package_name
+
+conda --help
+
+conda install --help
+
+安装Anaconda并启动一个环境之后,如何让Jupyter Notebook在我们要的环境中启动呢?
+conda install jupyter notebook
+
+# 生成配置
+jupyter notebook --generate-config
+# 编辑配置
+nano ~/.jupyter/jupyter_notebook_config.py
+# 写入这三行
+c.NotebookApp.ip = '0.0.0.0' # 允许任何 IP 访问
+c.NotebookApp.port = 8888 # 指定端口
+c.NotebookApp.open_browser = False # 不自动开浏览器
+# 重启jupyter
+jupyter notebook
+
+为了让 Jupyter Notebook 能识别该环境中的 Python 解释器,你需要在该环境中安装 ipykernel:
+conda install ipykernel
+
+将该环境注册为 Jupyter 的一个内核(kernel),这样启动 Jupyter Notebook 后就能选择这个内核:
+python -m ipykernel install --user --name myenv --display-name "Python (myenv)"
+
+这里 --name 指定内核的名称,--display-name 是在 Jupyter Notebook 界面中显示的名称,你可以根据需要自定义。
+jupyter notebook
+
+Jupyter Notebook 本身没有官方语言包,但可以用第三方扩展 jupyter_contrib_nbextensions和notebook-translation来实现部分汉化
pip install jupyter_contrib_nbextensions
+jupyter contrib nbextension install --user
+pip install jupyter-notebook-translation
+
+++当然,你也可以使用其他编辑器/IDE如 Sublime Text 或者 JetBrains 系列的 PyCharm 。
+
++UV(由 Astral 团队开发)是一个用 Rust 编写的高性能 Python 包管理器,提供类似 Conda 的虚拟环境管理和依赖解析功能,在大多数场景下比 pip 和 Conda 快 10–100 倍。它通过命令行工具如
+uv venv(创建/管理虚拟环境)和uv pip(安装/锁定/同步依赖)覆盖传统的 Conda 流程,但本身不管理底层的 C/C++ 库,因此对于 GDAL、SciPy 等需要系统级二进制依赖的包,仍建议先通过系统包管理器或 Conda 安装,然后用 UV 管理 Python 包。
wget -qO- https://astral.sh/uv/install.sh | sh
+
+# 创建虚拟环境,指定 Python 版本
+uv venv --python 3.12
+
+# 激活环境
+source .venv/bin/activate
+
+# 退出环境
+deactivate
+
+# 删除环境
+rm -rf .venv
+
+uv run python
+uv run jupyter lab
+
+uv run python -m ipykernel install --user --name bank --display-name "Python (bank)"
+
+uv add tensorflow
+uv pip install requests fastapi uvicorn sqlalchemy
+
+++安装完成后,UV 会自动更新
+uv.lock文件锁定依赖版本,保证环境可复现。
创建一个 pyproject.toml:
[tool.uv.dependencies]
+fastapi = "*"
+uvicorn = "*"
+sqlalchemy = "*"
+
+然后同步环境:
+uv pip sync
+
+这会根据 pyproject.toml + uv.lock 安装和锁定所有依赖。
uv pip list # 列出已安装包
+uv pip uninstall numpy
+
+| Conda 操作 | UV 对应 |
|---|---|
conda create -n env python=3.x | uv venv --python 3.x |
conda activate env | source .venv/bin/activate 或 uv venv activate |
conda install pkg1 pkg2 | uv pip install pkg1 pkg2 |
conda env export > env.yml | 自动生成 uv.lock 或 uv pip compile requirements.in |
conda env update -f env.yml | uv pip sync(根据 uv.lock 或 pyproject.toml 同步) |
conda list | uv pip list |
首先安装 nbformat 和 nbconvert包:
+conda install nbformat nbconvert -y
+touch ipynb2md.py && nano ipynb2md.py
+
+写入以下脚本:
+import nbformat
+from nbconvert import MarkdownExporter
+from pathlib import Path
+
+def ipynb_to_md(ipynb_path: Path, output_dir: Path):
+ """单个 ipynb 转 md"""
+ with open(ipynb_path, "r", encoding="utf-8") as f:
+ nb = nbformat.read(f, as_version=4)
+
+ exporter = MarkdownExporter()
+ body, resources = exporter.from_notebook_node(nb)
+
+ output_file = output_dir / (ipynb_path.stem + ".md")
+ with open(output_file, "w", encoding="utf-8") as f:
+ f.write(body)
+
+ print(f"✔ 转换完成: {ipynb_path} -> {output_file}")
+
+def batch_convert(input_dir: str, output_dir: str = "markdown_output"):
+ input_dir = Path(input_dir)
+ output_dir = Path(output_dir)
+ output_dir.mkdir(parents=True, exist_ok=True)
+
+ for ipynb_file in input_dir.glob("*.ipynb"):
+ ipynb_to_md(ipynb_file, output_dir)
+
+if __name__ == "__main__":
+ # 修改这里的目录路径即可
+ batch_convert(input_dir=".")
+
+运行脚本:
+python ipynb2md.py
+
+脚本会自动扫描当前目录下的所有 .ipynb 文件,并把 .md 文件输出到 markdown_output/ 文件夹。
+Done.
+ +前言 由于 Windows 中开发环境较 linux 复杂,这里总结 Windows 中使用 VScode 开发 C/C++ 的环境配置。
+Extensions 中安装 Chinese(simplified) 插件,重启即可变为中文;cpptools-windows-x64.vsix
+的插件并在扩展中从VSIX安装,然后搜索 Code Runner 并安装。首先打开官方文档,然后点击左侧的 Downloads,再点击 Pre-built Toolchains。往下拉,可以看到许多系统的下载包,这里我们选MinGW-W64-builds并点击。页面自动跳转,再点击最上方的 MinGW-W64-builds 下的 GitHub 链接。
进入Github,找到x86_64-14.2.0-release-win32-seh-ucrt-rt_v12-rev1.7z(版本会更新,选择最新的即可)点击然后下载。
下载完成后解压得到 mingw64 文件夹,将其移动到C:\Program Files下,随后复制该文件夹中/bin的路径。
按下 Win + S,在搜索框中输入“系统环境变量”,点击“编辑系统环境变量“,点击环境变量。在下方的系统变量中,选中Path,然后点击编辑,点击右侧的新建,然后黏贴刚刚拷贝的路径,随后一直用确定退出。
检验是否成功:在cmd中输入gcc -v,如果有版本号则成功。
.cpp文件,里面代码可以是#include <iostream>
+
+int main() {
+ std::cout << "Hello" << std::endl;
+ return 0;
+}
+
+保存,然后点击右上角的三角形,选择“运行C/C++文件”。此时上方的搜索框会有弹出,点击“C/C++: g++.exe 构建和调试活动文件”。 然后会生成一个 .vscode 的文件夹,里面包含 tasks.json 文件。打开这个文件,然后按需调整,设置栈空间(这里设置成了256MB)和 C++ 标准(这里设置成C++17)。
+接着生成调试文件,用于进行 debug。点击左侧的运行和调试,然后点击“创建 launch.json 文件”。点击弹出的“另外 C++ (GDB/LLDB) 个选项”。
+点击右下角的“添加配置”,然后点击“C/C++: (gbd) 启动”。对Program部分进行修改(编译产物的路径)。
+++手动编译:
+g++ <源代码的相对路径>手动运行编译产物:一般为./a.out
至此 Visual Studio Code 的 C++ 环境已经配置完成。
+++在ubuntu上配置环境需要安装
+sudo apt install build-essential gdb cmake clangd clang-format libstdc++-dev
Done.
+ +