阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Coreseek(Sphinx)简单应用及在LAMP中的注意事项

421次阅读
没有评论

共计 10078 个字符,预计需要花费 26 分钟才能阅读完成。

前言:

在本文中我将给大家带来 Coreseek(Sphinx)在 PHP 中的一个简单的例子、并在后面给大家讲一下 Coreseek(Sphinx)在 LAMP 环境中的一些注意事项,比如 searchd 的开机启动呀,Sphinx 实时索引啊。

有关 coreseek(sphinx)在 LAMP 上的安装以及配置、使用大家请参考我之前的两篇博客:

  1. CentOS 7 下安装 Coreseek 中文检索引擎  http://www.linuxidc.com/Linux/2017-05/143599.htm
  2. LAMP+Coreseek 中文检索引擎使用详解  http://www.linuxidc.com/Linux/2017-05/143600.htm

PS:这里用到的数据库和数据表都是在前面两篇博客中创建的。

一、coreseek+mysql+php 的一个简单使用:模拟搜索引擎

1、创建搜索首页:index.php

<html>
<head>
    <title>测试搜索</title>
</head>
<body>
    <h1>简单 PHP 搜索引擎</h1>
    <form action='find.php' method='post'>
    请输入搜索关键字:<input type='text' name='find'><br>
    <input type='submit' value='提交搜索关键字'>
    </form>
</body>
</html>

效果:
Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

2、处理并显示搜索结果页面:find.php

<html>
<head><title>Result</title></head>
<body>
    <h1>搜索结果展示 www.linuxidc.com</h1>
    <?php

        $keyword = $_POST['find'];

        $sphinx = new SphinxClient();

        // 设置主机和端口号
        $sphinx->SetServer("localhost",9312);

        // 搜索匹配方案
        $sphinx->SetMatchMode(SPH_MATCH_ANY);

        //query('a','b'); 在 b 索引中搜索关键字 a,* 表示所有索引
        $result = $sphinx -> query("$keyword","*");

        $ids = join(',',array_keys($result['matches']));

        $mysql = new mysqli('localhost','root','zhongjin','test');

        $mysql->query("SET NAMES utf8");

        $sql = "SELECT * FROM documents WHERE id IN({$ids})";

        $res = $mysql->query($sql);

        $count = $res->num_rows;

        // 该数组设置搜索关键字的显式样式
        /*
        $opts = array(
            'before_match' => "<font style='font-weight:bold;color:#f00'>",
            'after_match'  => "</font>",
        );
        */
        $opts = array('before_match'  => "<button style='font-weight:bold;color:#f00'>",
            'after_match'   => "</button>",
        );

        if($count > 0){while($ret = $res->fetch_assoc()){// 使搜索关键字高亮显示
                $row = $sphinx -> buildExcerpts($ret,'main',$keyword,$opts);

                echo "标题:{$row[4]}<br>";

                echo "内容:{$row[5]}";

                echo "<hr>";
            }

            echo "搜索结果 {$count} 条。";

        }else{echo "无搜索结果!";

        }

    ?>
</body>
</html>

当我搜索’LSGO 实验室‘时,效果如下:

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

这就是 sphinx+MySQL+php 的一个简单应用,以及使搜索关键字高亮显示。

二、sphinx 的实时索引

1、为什么要实现 sphinx 实时索引?

看看 coreseek 增量索引模拟实时索引 http://www.linuxidc.com/Linux/2017-05/143601.htm,在这里就引用该篇文章的内容:

有这么一种常见的情况:整个数据集非常大,以至于难于经常性的重建索引,但是每次新增的记录却相当地少。一个典型的例子是:一个论坛有 1000000 个已经归档的帖子,但每天只有 1000 个新帖子。

在这种情况下可以用所谓的“主索引+增量索引”(main+delta)模式来实现“近实时”的索引更新。

这种方法的基本思路是设置两个数据源和两个索引,对很少更新或根本不更新的数据建立主索引,而对新增文档建立增量索引。在上述例子中,那 1000000 个已经归档的帖子放在主索引中,而每天新增的 1000 个帖子则放在增量索引中。增量索引更新的频率可以非常快,而文档可以在出现几分种内就可以被检索到。

确定具体某一文档的分属那个索引的分类工作可以自动完成。一个可选的方案是,建立一个计数表,记录将文档集分成两部分的那个文档 ID,而每次重新构建主索引时,这个表都会被更新。

这里再用我的理解跟大家陈述一遍(如果大家有看我的前面两篇博客,这里会看的非常明白):

在前面我有一张 documents 表,现在我要往里面添加一篇文章,我想使这篇文章被检索到,就要执行 /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --all --rotate,要想减少能够检索的时间,我们可以使用 crontab 实现每分钟执行一次该命令。

然而这条命令是把整张表重新建立主数据索引,假如该表现在已经有好几千万条数据了,如果把整张表的数据重新建立索引,就会大量的消耗服务器 CPU 和内存。

上面说的解决方案就是,我能不能仅仅对今天新增的数据建立索引,主数据索引保持不变?毕竟一天内新增的数据不会太多。

这里实现的办法就是“主索引 + 增量索引”,原来的数据保存在主索引里面,而新增的数据就保存在增量索引里面,在服务器空闲的时候(一般在凌晨),在将增量索引并到主索引中去,这样就不会影响到第二天的建立增量索引。

2、建立计数表

该表的作用是记录将文档集分成两部分的那个文档 ID(一部分保存在主数据索引,一部分保存在增量索引),其实就是昨晚将增量索引并入主数据索引时 documents 数据表的 id 的最大值,而每次重新构建主索引时,这个表都会被更新。

创建计数表:

mysql -uroot -pzhongjin test;

CREATE TABLE sph_counter(counter_id INT PRIMARY KEY NOT NULL,
    max_doc_id INT NOT NULL
);

3、修改配置文件 csft.conf

在修改配置文件之前,给大家说一下 mysql 中的 REPLACE INTO 的用法:

使用 REPLACE INTO 的时候会带上一个主键,假如目标数据表中对应的该主键没有数据,那么 REPLACE INTO 就会往里面插数据(相当于 INSERT INTO)。假如该主键已经有数据了,REPLACE INTO 就会更新该条数据。

修改配置文件 csft.conf:

#1、在主数据源中(source main{})修改:

#新增一行,作用是更新 sph_counter 表
sql_query_pre = REPLACE INTO sph_counter SELECT 1,MAX(id) FROM documents;

#2、将增量数据源(source src1throttled : src1{})的注释打开

#修改增量数据源名字并添加如下内容:source delta : main{
    sql_ranged_throttle            = 100
    sql_query_pre = SET NAMES UTF8
    sql_query = \ 
        SELECT id,group_id,UNIX_TIMESTAMP(date_added) AS date_added,title,content FROM \ 
        documents WHERE id > (SELECT max_doc_id FROM sph_counter WHERE counter_id = 1) 
}

3、将增量数据索引(index test1stemmed : test1){})的注释打开

#修改增量数据索引名字并添加如下内容:index delta : main
{
    source = delta
    path = /usr/local/coreseek/var/data/delta
    morphology = stem_en
}

注意:增量数据源的 sql 语句搜索出来的结果字段一定要与主数据源的对称,因为他俩是继承关系,如果不对称,就会报错:字段不统一

更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2017-05/143603p2.htm

4、测试增量索引 + 主索引

到目前为止,sph_counter 表是空的,现在我们执行更新索引命令:

/usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --all --rotate

–all 表示生成所有索引,包括主数据索引(main)和增量数据索引(delta)
–rotate 是因为由于现在 searchd 服务在进行,必须加该参数

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

图中可以看到,该命令创建更新了两个索引(main 和 delta),这时候我们再看看 sph_counter 表和 documents 表:

mysql -uroot -pzhongjin test

SELECT * FROM sph_counter;

SELECT id,title,content FROM documents;

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

可以看到,现在 sph_countter 表中保存的是 documents 表中的 id 的最大值。

================== 分割线 ====================

往 documents 表中插入一条数据,

INSERT INTO documents(group_id,group_id2,date_added,title,content) VALUES(4,10,NOW(),'LINUX 技术','在华北电力大学 LSGO 实验室学习 LINUX 技术');

按照前面说的,对新增数据建立增量索引,而不是对索引数据重新建立主数据索引:

/usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf delta --rotate

ps:假如对单个类型建立索引,直接用索引名代替 –all , 例如为主数据源建立主数据索引,/usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf main --rotate

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

================== 分割线 ====================

我们搜索‘Linux’试试:

/usr/local/coreseek/bin/search -c /usr/local/coreseek/etc/csft.conf LINUX

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

发现结果是来自增量索引 delta 的。也就是说现在主数据索引里面是不包含该条数据的。

PS:假如现在你在 PHP 中使用 sphinx 技术的话,在搜索关键字的时候,一定要用 $sphinx -> query("{$keyword}","*"), 因为“*”表示所有的索引,而不仅仅是主数据索引。

最后我们还要实现将增量索引合并到主数据索引中去,再将 sph_counter 表的 max_doc_id 字段更新。

5、用 crontab 实现定时建立增量索引和主数据索引

我们将建立增量索引和主数据索引的命令写成一个可执行脚本,放到 /usr/local/coreseek/etc/init 下:

cd /usr/local/coreseek/etc

mkdir init

cd init

# 建立主数据索引脚本
touch main.sh

# 建立增量数据索引脚本
touch delta.sh

# 添加权限:
chmod 755 *.sh

添加日志文件,方便以后查阅

cd /usr/local/coreseek/var/log

# 建立主数据索引日志文件
touch main.log

# 建立增量数据索引脚本
touch delta.log

# 添加权限
chmod 755 main.log delta.log

往 main.sh 添加以下内容:

#!/bin/bash
# main.sh   

/usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf main --rotate >> /usr/local/coreseek/var/log/main.log

echo "==============================================================" >> /usr/local/coreseek
    /var/log/main.log

往 delta.sh 添加以下内容:

#!/bin/bash
# delta.sh   

/usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf delta --rotate >> /usr/local/coreseek/var/log/delta.log

echo "==============================================================" >> /usr/local/coreseek
    /var/log/delta.log

==================================================

我们的目标是:每五分钟创建一次增量索引,每天凌晨三点合并增量索引,重建主数据索引。

使用 crontab 定时执行 main.sh 和 delta.sh

crontab -e

# 添加以下两行
*/5 * * * * /usr/local/coreseek/etc/init/delta.sh
00 03 * * * /usr/local/coreseek/etc/init/main.sh

好了,现在 sphinx 的实时索引就算是完成了。

三、配置 searchd 的开机自启:

1、原理:

系统开机启动时会去加载 /etc/init.d/ 下面的脚本,通常而言每个脚本文件会自定义实现程序的启动;若想将新的程序开机自启动,只需在该目录下添加一个自定义启动程序的脚本,然后设置相应规则即可。

如在这里我们在 /etc/init.d/ 下新建一个 auto_coreseek 的脚本,开机启动时会去加载执行该脚本

2、编写开机启动脚本:

创建脚本 auto_coreseek

cd /etc/init.d

vim auto_coreseek

在 auto_coreseek 中添加以下内容:

#!/bin/sh
#chkconfig:2345 80 90
#description:auto_coreseek

/usr/local/coreseek/bin/searchd -c /usr/local/coreseek/etc/csft.conf

添加权限:

chmod 755 auto_coreseek

启动测试:

# 先把该进程关掉
killall searchd

/etc/init.d/auto_coreseek start

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

添加到开机启动项:

chkconfig auto_coreseek on

重启服务器测试:

reboot

ps aux | grep searchd
# 或
netstat -tunlp | 9312

好了,完成!

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-05/143603.htm

前言:

在本文中我将给大家带来 Coreseek(Sphinx)在 PHP 中的一个简单的例子、并在后面给大家讲一下 Coreseek(Sphinx)在 LAMP 环境中的一些注意事项,比如 searchd 的开机启动呀,Sphinx 实时索引啊。

有关 coreseek(sphinx)在 LAMP 上的安装以及配置、使用大家请参考我之前的两篇博客:

  1. CentOS 7 下安装 Coreseek 中文检索引擎  http://www.linuxidc.com/Linux/2017-05/143599.htm
  2. LAMP+Coreseek 中文检索引擎使用详解  http://www.linuxidc.com/Linux/2017-05/143600.htm

PS:这里用到的数据库和数据表都是在前面两篇博客中创建的。

一、coreseek+mysql+php 的一个简单使用:模拟搜索引擎

1、创建搜索首页:index.php

<html>
<head>
    <title>测试搜索</title>
</head>
<body>
    <h1>简单 PHP 搜索引擎</h1>
    <form action='find.php' method='post'>
    请输入搜索关键字:<input type='text' name='find'><br>
    <input type='submit' value='提交搜索关键字'>
    </form>
</body>
</html>

效果:
Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

2、处理并显示搜索结果页面:find.php

<html>
<head><title>Result</title></head>
<body>
    <h1>搜索结果展示 www.linuxidc.com</h1>
    <?php

        $keyword = $_POST['find'];

        $sphinx = new SphinxClient();

        // 设置主机和端口号
        $sphinx->SetServer("localhost",9312);

        // 搜索匹配方案
        $sphinx->SetMatchMode(SPH_MATCH_ANY);

        //query('a','b'); 在 b 索引中搜索关键字 a,* 表示所有索引
        $result = $sphinx -> query("$keyword","*");

        $ids = join(',',array_keys($result['matches']));

        $mysql = new mysqli('localhost','root','zhongjin','test');

        $mysql->query("SET NAMES utf8");

        $sql = "SELECT * FROM documents WHERE id IN({$ids})";

        $res = $mysql->query($sql);

        $count = $res->num_rows;

        // 该数组设置搜索关键字的显式样式
        /*
        $opts = array(
            'before_match' => "<font style='font-weight:bold;color:#f00'>",
            'after_match'  => "</font>",
        );
        */
        $opts = array('before_match'  => "<button style='font-weight:bold;color:#f00'>",
            'after_match'   => "</button>",
        );

        if($count > 0){while($ret = $res->fetch_assoc()){// 使搜索关键字高亮显示
                $row = $sphinx -> buildExcerpts($ret,'main',$keyword,$opts);

                echo "标题:{$row[4]}<br>";

                echo "内容:{$row[5]}";

                echo "<hr>";
            }

            echo "搜索结果 {$count} 条。";

        }else{echo "无搜索结果!";

        }

    ?>
</body>
</html>

当我搜索’LSGO 实验室‘时,效果如下:

Coreseek(Sphinx)简单应用及在 LAMP 中的注意事项

这就是 sphinx+MySQL+php 的一个简单应用,以及使搜索关键字高亮显示。

二、sphinx 的实时索引

1、为什么要实现 sphinx 实时索引?

看看 coreseek 增量索引模拟实时索引 http://www.linuxidc.com/Linux/2017-05/143601.htm,在这里就引用该篇文章的内容:

有这么一种常见的情况:整个数据集非常大,以至于难于经常性的重建索引,但是每次新增的记录却相当地少。一个典型的例子是:一个论坛有 1000000 个已经归档的帖子,但每天只有 1000 个新帖子。

在这种情况下可以用所谓的“主索引+增量索引”(main+delta)模式来实现“近实时”的索引更新。

这种方法的基本思路是设置两个数据源和两个索引,对很少更新或根本不更新的数据建立主索引,而对新增文档建立增量索引。在上述例子中,那 1000000 个已经归档的帖子放在主索引中,而每天新增的 1000 个帖子则放在增量索引中。增量索引更新的频率可以非常快,而文档可以在出现几分种内就可以被检索到。

确定具体某一文档的分属那个索引的分类工作可以自动完成。一个可选的方案是,建立一个计数表,记录将文档集分成两部分的那个文档 ID,而每次重新构建主索引时,这个表都会被更新。

这里再用我的理解跟大家陈述一遍(如果大家有看我的前面两篇博客,这里会看的非常明白):

在前面我有一张 documents 表,现在我要往里面添加一篇文章,我想使这篇文章被检索到,就要执行 /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --all --rotate,要想减少能够检索的时间,我们可以使用 crontab 实现每分钟执行一次该命令。

然而这条命令是把整张表重新建立主数据索引,假如该表现在已经有好几千万条数据了,如果把整张表的数据重新建立索引,就会大量的消耗服务器 CPU 和内存。

上面说的解决方案就是,我能不能仅仅对今天新增的数据建立索引,主数据索引保持不变?毕竟一天内新增的数据不会太多。

这里实现的办法就是“主索引 + 增量索引”,原来的数据保存在主索引里面,而新增的数据就保存在增量索引里面,在服务器空闲的时候(一般在凌晨),在将增量索引并到主索引中去,这样就不会影响到第二天的建立增量索引。

2、建立计数表

该表的作用是记录将文档集分成两部分的那个文档 ID(一部分保存在主数据索引,一部分保存在增量索引),其实就是昨晚将增量索引并入主数据索引时 documents 数据表的 id 的最大值,而每次重新构建主索引时,这个表都会被更新。

创建计数表:

mysql -uroot -pzhongjin test;

CREATE TABLE sph_counter(counter_id INT PRIMARY KEY NOT NULL,
    max_doc_id INT NOT NULL
);

3、修改配置文件 csft.conf

在修改配置文件之前,给大家说一下 mysql 中的 REPLACE INTO 的用法:

使用 REPLACE INTO 的时候会带上一个主键,假如目标数据表中对应的该主键没有数据,那么 REPLACE INTO 就会往里面插数据(相当于 INSERT INTO)。假如该主键已经有数据了,REPLACE INTO 就会更新该条数据。

修改配置文件 csft.conf:

#1、在主数据源中(source main{})修改:

#新增一行,作用是更新 sph_counter 表
sql_query_pre = REPLACE INTO sph_counter SELECT 1,MAX(id) FROM documents;

#2、将增量数据源(source src1throttled : src1{})的注释打开

#修改增量数据源名字并添加如下内容:source delta : main{
    sql_ranged_throttle            = 100
    sql_query_pre = SET NAMES UTF8
    sql_query = \ 
        SELECT id,group_id,UNIX_TIMESTAMP(date_added) AS date_added,title,content FROM \ 
        documents WHERE id > (SELECT max_doc_id FROM sph_counter WHERE counter_id = 1) 
}

3、将增量数据索引(index test1stemmed : test1){})的注释打开

#修改增量数据索引名字并添加如下内容:index delta : main
{
    source = delta
    path = /usr/local/coreseek/var/data/delta
    morphology = stem_en
}

注意:增量数据源的 sql 语句搜索出来的结果字段一定要与主数据源的对称,因为他俩是继承关系,如果不对称,就会报错:字段不统一

更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2017-05/143603p2.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计10078字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7987004
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
如何安装2026年最强个人助理ClawdBot、完整安装教程

如何安装2026年最强个人助理ClawdBot、完整安装教程

如何安装 2026 年最强个人助理 ClawdBot、完整安装教程 一、前言 学不完,根本学不完!近期,一款名...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
150元打造低成本NAS小钢炮,捡一块3865U工控板

150元打造低成本NAS小钢炮,捡一块3865U工控板

150 元打造低成本 NAS 小钢炮,捡一块 3865U 工控板 一块二手的熊猫 B3 工控板 3865U,搭...
从“纸堆”到“电子化”文档:用这个开源系统打造你的智能文档管理系统

从“纸堆”到“电子化”文档:用这个开源系统打造你的智能文档管理系统

从“纸堆”到“电子化”文档:用这个开源系统打造你的智能文档管理系统 大家好,我是星哥。公司的项目文档存了一堆 ...
安装并使用谷歌AI编程工具Antigravity(亲测有效)

安装并使用谷歌AI编程工具Antigravity(亲测有效)

  安装并使用谷歌 AI 编程工具 Antigravity(亲测有效) 引言 Antigravity...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

  三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Andr...
星哥带你玩飞牛NAS-16:飞牛云NAS换桌面,fndesk图标管理神器上线!

星哥带你玩飞牛NAS-16:飞牛云NAS换桌面,fndesk图标管理神器上线!

  星哥带你玩飞牛 NAS-16:飞牛云 NAS 换桌面,fndesk 图标管理神器上线! 引言 哈...
开源MoneyPrinterTurbo 利用AI大模型,一键生成高清短视频!

开源MoneyPrinterTurbo 利用AI大模型,一键生成高清短视频!

  开源 MoneyPrinterTurbo 利用 AI 大模型,一键生成高清短视频! 在短视频内容...
仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

还在忍受动辄数百兆的“全家桶”监控软件?后台偷占资源、界面杂乱冗余,想查个 CPU 温度都要层层点选? 今天给...
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...