当前位置: 首页 > news >正文

K8S学习教程(三):在PetaExpress KubeSphere 容器部署 Wiki 系统 wiki.js 并启用中文全文检索

                                                                   

   背景

  wiki.js 是非常优秀的开源 Wiki 系统,尽管在与 xwiki 功能相比 ,还不算完善,但也在不断进步。 常用的功能还是比较实用的,如:Wiki 写 作、分享、权限管理功能还是非常实用的,UI 设计非常的漂亮,精美的界面和直观的操作体验,能够满足小团队的基本知识管理需求。

  认真阅读全文,教你怎么领取礼品

  我们需要在 PetaExpress KubeSphere 容器平台中部署 Kubernetes集群

  在 Peta Express 中部署 Kubernetes 非常的简单方便,直接使用 PetaExpress 中内置的 QKE 就可以了,首先我们需要登录到 PetaExpress 控制台(登录地址:https://cn.petaexpress.com ),在产品与服务中找到 AppCenter 控制台 → 应用中心。

  找到 QKE 立即部署即可。

  按照提示输入名称,选择集群规模等关键信息,然后提交就可以了。但需要注意集群的配置,如果是开发测试可以选择 “基础型开发环境” 或 “企业型测试环境”,如果是生产的话则可以选择 “基础型生产环境” 或 “企业型生产环境”,也可以自定义集群规模和HA。

  根据集群的规模,部署时间大致2分钟到10分钟不等,速度还是非常的快的,能在极短的时间内完成。部署完 Kubernetes(K8S),需要安装 OpenEBS,完成这一环节后就可以安装 Redis 了。

  准备 storageclass

  我们使用 OpenEBS 作为存储,OpenEBS 默认安装的 Local StorageClass 在 Pod 销毁后自动删除,不适合用于我的数据存储,我们在

  Local StorageClass 基础上稍作修改,创建新的 StorageClass,允许 Pod 销毁后,PV 内容继续保留,手动决定怎么处理。

  在项目空间的 存储 → 存储类型 → 创建 进行storageClass的创建

  名称:localretain

  存储系统:自定义

  存储卷扩容:否

  回收机制:Retain

  访问模式:ReadWriteOnce

  存储系统:openebs.io/local

  存储卷延迟绑定:延迟绑定编辑完成后点击创建,或直接点击 编辑YAML ,将以下yaml内容粘贴后点击创建

  部署 PostgreSQL 数据库

  鉴于我们团队在多个项目中也需要使用 PostgreSQL, 为了提高 PostgreSQL 数据库的利用率和统一管理,我们独立部署 PostgreSQL,并在

  安装 wiki.js 时,配置为使用外部数据库。

  准备用户名密码配置

  我们使用 Secret 保存 PostgreSQL 用户密码等敏感信息。

  在项目空间的 配置 → 保密字典 → 创建 进行保密字典的创建。

  1 apiVersion: storage.k8s.io/v1

  2 kind: StorageClass

  3 metadata:

  4annotations:

  5cas.openebs.io/config: |

  6- name: StorageType

  7value: "hostpath"

  8- name: BasePath

  9value: "/var/openebs/localretain/"

  10openebs.io/cas-type: local

  11storageclass.beta.kubernetes.io/is-default-class: "false"

  12storageclass.kubesphere.io/supported-access-modes: '["ReadWriteOnce"]'

  13name: localretain

  14 provisioner: openebs.io/local

  15 reclaimPolicy: Retain

  16 volumeBindingMode: WaitForFirstConsumer

  部署 PostgreSQL 数据库

  鉴于我们团队在多个项目中也需要使用 PostgreSQL, 为了提高 PostgreSQL 数据库的利用率和统一管理,我们独立部署 PostgreSQL,并在

  安装 wiki.js 时,配置为使用外部数据库。

  准备用户名密码配置

  我们使用 Secret 保存 PostgreSQL 用户密码等敏感信息。

  在项目空间的 配置 → 保密字典 → 创建 进行保密字典的创建。

  首先我们定义一个名称就叫 postgres-prod 点击下一步,类型保持默认设置即可, 添加键值对数据。

  键为 POSTGRES_PASSWORD ,值为 password ( 密码自行准备修改 )

     准备数据库初始化脚本

  使用 ConfigMap 保存数据库初始化脚本,在 数据库创建时,将 ConfigMap 中的数据库初始化脚本挂载到 /docker-entrypoint-initdb.d, 容器初 始化时会自动执行该脚本。

  在项目空间的 配置 → 配置字典 → 创建 进行配置字典的创建。

  名称就叫 wikijs-postgres-init 然后下一步,添加键值对数据。

    键为 init.sql ,值为 

  1 CREATE DATABASE wikijs;

  2 CREATE USER wikijs with password 'password';

  3 GRANT CONNECT ON DATABASE wikijs to wikijs;

  4GRANT USAGE ON SCHEMA public TO wikijs;

  5 GRANT SELECT,update,INSERT,delete ON ALL TABLES IN SCHEMA public TO wikijs;

  6ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO wikijs;

以上 wikijs 用户的密码自行准备,明文保存。

  准备存储

  我们使用 OpenEBS 来提供存储服务。可以通过创建 PVC 来提供持久化存储。

  这里声明一个 10G 的 PVC。

  需按照以下步骤操作

  在项目空间的 存储 → 存储卷 → 创建 进行PVC的创建。

  名称就叫 postgres-prod-data ,然后下一步,进行存储设置。

  存储类型: localretain

  访问模式: ReadWriteOnce

  存储卷容量: 10G

  高级设置无需修改,点击创建按钮即可。

部署 PostgreSQL 数据库

  在前面的步骤准备好各种配置信息和存储后,就可以开始部署 PostgreSQL 服务了。

  我们的 Kubernetes 没有配置存储阵列,使用的是 OpenEBS 作为存储,采用 Deployment 方式部署 PostgreSQL。

  需按照以下步骤操作

  在项目空间的 应用负载 → 工作负载 → 部署 → 创建 进行 PostgreSQL 服务的创建。

  基本信息里名称就叫做 postgres-prod ,然后进行下一步容器组设置

  容器组配置

  这一步的核心就是配置 postgres 的容器。

  容器组副本数量选择1,点击添加容器镜像选择 dockerhub 中的 abcfy2/zhparser:12-alpine ,并选择使用默认端口,容器名称改为 postgres-prod

  勾选 环境变量 ,点击 引用配置字典或保密字典 ,资源选择 postgres-prod 保密字典,资源中的键选择 POSTGRES_PASSWORD ,之后点击对勾完成容器配置,点击下一步配置 存储卷设置

  存储设置

在这一步有两个操作

  挂载存储卷

  挂载配置字典

  挂载存储卷

  选择现有存储卷 postgres-prod-data ,权限为读写,挂载地址为 /var/lib/postgresql/data ,配置好后点击对勾完成配置

挂载配置字典

  选择配置字典 wikijs-postgres-init ,权限为只读,挂载地址为 /docker-entrypoint-initdb.d ,配置好后点击对勾完成配置

  配置好后如下图

  点击下一步进入最后的高级设置

  高级设置 里是一些额外配置,可以根据自己场景选择调整配置,调整完成后点击 创建 。创建供其他 Pod 访问的 Service

  在项目空间的 应用负载 → 服务 → 创建   进行服务的创建

  名称就叫 postgres-prod 然后下一步,进入服务设置

  内部访问模式选择 虚拟IP地址 ,指定工作负载选择 postgres-prod

  端口协议:TCP

  端口名称:tcp-5432

  容器端口:5432

  服务端口:5432

点击下一步进入高级设置

  高级设置 里是一些额外配置,可以根据自己场景选择调整配置,调整完成后点击 创建 。

  部署 wiki.js

  准备用户名密码配置

  我们使用 Secret 保存 wiki.js 用于连接数据库的用户名密码等敏感信息。

  在项目空间的 配置 → 保密字典 → 创建 进行保密字典的创建。

名称就叫 wikijs 然后下一步,类型选择默认, 添加键值对数据。

  键为 DB_USER ,值为 wikijs ( 和上方初始化脚本中的用户名保持一致 )

  键为 DB_PASS ,值为 password ( 和上方初始化脚本中的密码保持一致 )

  准备数据库连接配置

  我们使用 ConfigMap 保存 wiki.js 的数据库连接信息。

  在项目空间的 配置 → 配置字典 → 创建 进行配置字典的创建。

名称就叫 wikijs 然后下一步,添加键值对数据。

  键值对数据如下

  1DB_TYPE: postgres

  2 DB_HOST: postgres-prod

  3DB_PORT: 5432

  4 DB_NAME: wikijs创建数据库用户和数据库

  如果 PostgreSQL 数据库里没有创建 wikijs 用户和数据 ,需要手工完成一下工作:

  通过『数据库工具』连接 PostgreSQL 数据库,执行一下 SQL 语句,完成数据库和用户的创建、授权。

  以上 wikijs 的密码自行修改。

  部署 wiki.js

  这里我们采用 Deployment 方式部署 wiki.js。

  在项目空间的 应用负载 → 工作负载 → 部署 → 创建 进行 wiki.js 服务的创建。

  基本信息里名称就叫做 wikijs ,然后进行下一步容器组设置

  容器组配置

  这一步的核心就是配置 wikijs 的容器。

  容器组副本数量选择1,点击添加容器

  5 HA_ACTIVE: true

  1 CREATE DATABASE wikijs;

  2 CREATE USER wikijs with password 'password';

  3 GRANT CONNECT ON DATABASE wikijs to wikijs;

  4 GRANT USAGE ON SCHEMA public TO wikijs;

  5 GRANT SELECT,update,INSERT,delete ON ALL TABLES IN SCHEMA public TO wikijs;

  6 ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO wikijs;镜像选择 dockerhub 中的 requarks/wiki:2 ,并选择使用默认端口,容器名称改为 wikijs

  勾选 环境变量 ,点击 引用配置字典或保密字典 ,先添加刚才创建的保密字典 wikijs ,然后添加配置字典 wikijs ,之后点击对勾完成容器配置,点击下一步配置 

存储卷设置存储卷此处无需设置,点击下一步进入高级配置

  高级设置 里是一些额外配置,可以根据自己场景选择调整配置,调整完成后点击 创建 。

  创建访问 wiki.js 的 Service

  在项目空间的 应用负载 → 服务 → 创建 进行服务的创建名称就叫 wikijs 然后下一步,进入服务设置

  内部访问模式选择 虚拟IP地址 ,指定工作负载选择 wikijs

  端口协议:TCP

  端口名称:tcp-3000

  容器端口:3000

  服务端口:3000点击下一步进入高级设置,勾选外部访问,访问模式选择NodePort,完成后点击 创建 。

  然后可以使用NodePort的IP + Port进行访问wikijs。

  配置 wiki.js 支持中文全文检索

  wiki.js 的全文检索支持基于 PostgreSQL 的检索,也支持 Elasticsearch 等,相对来说, PostgreSQL 比较轻量级,本项目中,我们使用

  PostgreSQL 的全文检索。

  但是,因为 PostgreSQL 不支持中文分词,需要额外安装插件并配置启用中文分词,下面描述了为 wiki.js 启动基于 PostgreSQL 数据库中文

  分词的全文检索。

  授予 wikijs 用户临时超管权限

  通过数据库管理工具登录有超管权限的 PostgreSQL 用户,临时授予 wiki.js 用户临时超管权限,便于启动中文分词功能。

  启用数据库的中文分词能力

  使用数据库管理工具登录 PostgreSQL 数据库的 wikijs 用户,执行以下命令,启动数据库的中文分词功能。

  1 ALTER USER wikijs WITH SUPERUSER;

  1 CREATE EXTENSION pg_trgm;

  2

  3 CREATE EXTENSION zhparser;

  4 CREATE TEXT SEARCH CONFIGURATION pg_catalog.chinese_zh (PARSER = zhparser);

  5 ALTER TEXT SEARCH CONFIGURATION chinese_zh ADD MAPPING FOR n,v,a,i,e,l WITH simple;

  6

  7 -- 忽略标点影响

  8 ALTER ROLE wikijs SET zhparser.punctuation_ignore = ON;

  9

  -- 短词复合取消 wikijs 用户的临时超管权限

  登录 PostgreSQL 数据库 wikijs 用户,取消 wikijs 用户的超管权限。

  创建支持中文分词的配置 ConfigMap

  在项目空间的 配置 → 配置字典 → 创建 进行配置字典的创建。

  名称就叫 wikijs-zhparser 然后下一步,添加两个键值对数据。

  10 ALTER ROLE wikijs SET zhparser.multi_short = ON;

  11

  12-- 测试一下

  13select ts_debug('chinese_zh', '青春是最美好的年岁,青春是最灿烂的日子。每一个人的青春都无比宝贵,宝贵的青春只有与奋斗为伴才最闪光

 取消 wikijs 用户的临时超管权限

  登录 PostgreSQL 数据库 wikijs 用户,取消 wikijs 用户的超管权限。

  1 ALTER USER wikijs WITH NOSUPERUSER;

  创建支持中文分词的配置 ConfigMap

  在项目空间的 配置 → 配置字典 → 创建 进行配置字典的创建。

  

名称就叫 wikijs-zhparser 然后下一步,添加两个键值对数据。

1. 键为 definition.yml ,值为

  1 key: postgres

  2 title: Database - PostgreSQL

  3 description: Advanced PostgreSQL-based search engine.

  4 author: requarks.io

  5 logo: https://static.requarks.io/logo/postgresql.svg

  6 website: https://www.requarks.io/

  7 isAvailable: true

  8 props:

  9dictLanguage:

  10type: String

  11title: Dictionary Language

  12hint: Language to use when creating and querying text search vectors.2. 键为 engine.js ,值为

  13default: english

  14enum:

  15- simple

  16- danish

  17- dutch

  18- english

  19- finnish

  20- french

  21- german

  22- hungarian

  23- italian

  24- norwegian

  25- portuguese

  26- romanian

  27- russian

  28- spanish

  29- swedish

  30- turkish

  31- chinese_zh

  32order: 1

 2. 键为 engine.js ,值为

  1 const tsquery = require('pg-tsquery')()

  2 const stream = require('stream')

  3 const Promise = require('bluebird')

  4 const pipeline = Promise.promisify(stream.pipeline)

  5

  6 /* global WIKI */

  7

  8 module.exports = {

  9async activate() {

  10if (WIKI.config.db.type !== 'postgres') {

  11throw new WIKI.Error.SearchActivationFailed('Must use PostgreSQL database to activate this engine!')

  12}

  13},

  14async deactivate() {

  15WIKI.logger.info(`(SEARCH/POSTGRES) Dropping index tables...`)

  16await WIKI.models.knex.schema.dropTable('pagesWords')

  17await WIKI.models.knex.schema.dropTable('pagesVector')

  18WIKI.logger.info(`(SEARCH/POSTGRES) Index tables have been dropped.`)

  19},

  20/**

  21* INIT

  22*/

  23async init() {

  24WIKI.logger.info(`(SEARCH/POSTGRES) Initializing...`)

  25

  26// -> Create Search Index

  27const indexExists = await WIKI.models.knex.schema.hasTable('pagesVector')

  28if (!indexExists) {

  29WIKI.logger.info(`(SEARCH/POSTGRES) Creating Pages Vector table...`)

  30await WIKI.models.knex.schema.createTable('pagesVector', table => {

  31table.increments()

  32table.string('path')

  33table.string('locale')

  34table.string('title')

  35table.string('description')

  36table.specificType('tokens', 'TSVECTOR')

  37table.text('content')

  38})

  39}

  40// -> Create Words Index

  41const wordsExists = await WIKI.models.knex.schema.hasTable('pagesWords')

  42if (!wordsExists) {

  43WIKI.logger.info(`(SEARCH/POSTGRES) Creating Words Suggestion Index...`)

  44await WIKI.models.knex.raw(`

  45CREATE TABLE "pagesWords" AS SELECT word FROM ts_stat(

  46'SELECT to_tsvector(''simple'', "title") || to_tsvector(''simple'', "description") || to_tsvector(''s

  47)`)

  48await WIKI.models.knex.raw('CREATE EXTENSION IF NOT EXISTS pg_trgm')

  49await WIKI.models.knex.raw(`CREATE INDEX "pageWords_idx" ON "pagesWords" USING GIN (word gin_trgm_ops)`)

  50}

  51

  52WIKI.logger.info(`(SEARCH/POSTGRES) Initialization completed.`)

  53},

  54/**

  55* QUERY

  56*

  57* @param {String} q Query

  58* @param {Object} opts Additional options

  59*/

  60async query(q, opts) {

  61try {

  62let suggestions = []

  63let qry = `

  64SELECT id, path, locale, title, description

  65FROM "pagesVector", to_tsquery(?,?) query

  66WHERE (query @@ "tokens" OR path ILIKE ?)

  67`

  68let qryEnd = `ORDER BY ts_rank(tokens, query) DESC`

  69let qryParams = [this.config.dictLanguage, tsquery(q), `%${q.toLowerCase()}%`]

  70

  71if (opts.locale) {

  72qry = `${qry} AND locale = ?`

  73qryParams.push(opts.locale)

  74}

  75if (opts.path) {

  76qry = `${qry} AND path ILIKE ?`

  77qryParams.push(`%${opts.path}`)

  78}

  79const results = await WIKI.models.knex.raw(`

  80${qry}

  81${qryEnd}

  82`, qryParams)

  83if (results.rows.length < 5) {

  84const suggestResults = await WIKI.models.knex.raw(`SELECT word, word <-> ? AS rank FROM "pagesWords" WH

  85suggestions = suggestResults.rows.map(r => r.word)

  86}

  87return {

  88results: results.rows,

  89suggestions,

  90totalHits: results.rows.length

  91}

  92} catch (err) {

  93WIKI.logger.warn('Search Engine Error:')

  94WIKI.logger.warn(err)

  95}

  96},

  97/**

  98* CREATE

  99*

  100* @param {Object} page Page to create

  101*/

  102async created(page) {

  103await WIKI.models.knex.raw(`

  104INSERT INTO "pagesVector" (path, locale, title, description, "tokens") VALUES (

  105?, ?, ?, ?, (setweight(to_tsvector('${this.config.dictLanguage}', ?), 'A') || setweight(to_tsvector('${

  106)

  107`, [page.path, page.localeCode, page.title, page.description, page.title, page.description, page.safeConten

  108},

  109/**

  110* UPDATE

  111*

  112* @param {Object} page Page to update

  113*/

  114async updated(page) {

  115await WIKI.models.knex.raw(`

  116UPDATE "pagesVector" SET

  117title = ?,

  118description = ?,

  119tokens = (setweight(to_tsvector('${this.config.dictLanguage}', ?), 'A') ||

  120setweight(to_tsvector('${this.config.dictLanguage}', ?), 'B') ||

  121setweight(to_tsvector('${this.config.dictLanguage}', ?), 'C'))

  122WHERE path = ? AND locale = ?

  123`, [page.title, page.description, page.title, page.description, page.safeContent, page.path, page.localeCod

  124},

  125/**

  126* DELETE

  127*

  128* @param {Object} page Page to delete

  129*/

  130async deleted(page) {

  131await WIKI.models.knex('pagesVector').where({

  132locale: page.localeCode,

  133path: page.path

  134}).del().limit(1)

  135},

  136/**

  137* RENAME

  138*

  139* @param {Object} page Page to rename

  140*/

  141async renamed(page) {

  142await WIKI.models.knex('pagesVector').where({

  143locale: page.localeCode,

  144path: page.path

  145}).update({

  146locale: page.destinationLocaleCode,

  147path: page.destinationPath

  148})

  149},

  150/**

  151* REBUILD INDEX

  152

  */更新 wikijs 的 Deployment

  wiki.js 的基于 PostgreSQL 的全文检索引擎配置位于 /wiki/server/modules/search/postgres ,我们将前面配置的 ConfigMap 加载到这个目录。

  在项目空间的 应用负载 → 工作负载 → wikijs 进入 wikijs 工作负载的详情页

 点击左侧更多操作,选择编辑设置

   点击 存储卷 → 挂载配置字典或保密字典

 选择配置字典 wikijs-zhparser ,权限为只读,挂载地址为 /wiki/server/modules/search/postgres ,配置好后点击对勾完成配置

 点击确定完成存储卷的修改

  配置 wiki.js ,启用基于 PostgreSQL 的全文检索

  1. 新的 Deployment 创建完成后

  2. 打开 wiki.js 管理3. 点击搜索引擎

  4. 选择 Database - PostgreSQL

  5. 在 Dictionary Language 的下拉菜单里选择 chinese_zh。

  6. 点击应用,并重建索引。

  7. 完成配置。

  总结

  “K8S学习教程(三):在PetaExpress KubeSphere 容器部署 Wiki 系统 wiki.js 并启用中文全文检索”重点讲解了wiki.js的部署方式,特别强调了其

  对中文全文检索功能的支持。集成了 PostgreSQL 和 zhparser 中文分词插件。

  相对于标准的 wiki.js 安装部署过程,主要做了以下配置:

  1、wiki.js 镜像外挂了 ConfigMap ,用于修改原 Docker 镜像里关于 PostgreSQL 搜索引擎配置的信息,以支持 chinese_zh 选项。

  2、PostgreSQL 镜像采用了 abcfy2/zhparser:12-alpine ,这个镜像自带 zhparser 中文分词插件。

  凭此文章可以去petaexpress官网发工单 充值≥1美元送10美元,奖励数量有限先到先得。申领步骤:注册→登录→充值→发工单 回复“文章 网址+文章标题+申请奖励”,

                                                                                                                                            

               

                                                  

                                                                                                                                                                

              

                                                                                                                            

                                                                                                     

                

                                                                                

                                                                            

                                       

              

         

       

            

                  

                      

                                                    

                 

                                                                               

                        

         

                                     

                                 

                               

                     

           

              

                          

                    

                  

                  

                                    

                             

                                                           

                                                                         

                   

                                

                        

                                          

                 

                                                                               

                        

         

                                     

                                 

                                                      

                                                         

                                                                                                         

                                 

                                                                                 

     

                                         

                 

         

                               

                         

                                               

                                             

                                         

                                                                             

                                                                                                                    

                 

                   

          

                                  

                                            

                                                                        

         

                                                  

                                      

     

                         

                                                                                            

                                                                                    

                        

         

     

       

     

                                                                                    

                                                                                  

       

               

                                                              

                             

                                

                                       

        

              

          

                    

                                         

          

         

                                          

                                                                   

                                           

                                             

         

                                   

                                                           

       

                  

                         

              

                            

                                                 

                                                       

                   

          

                               

                                               

                               

     

                       

                 

                 

                         

                                               

                                             

                                         

                                                                             

                                                                                                                                        

                                                                           

                                    

                                         

                      

                                                      

                                 

        

              

          

                                                     

                                   

                    

                                                                                     

                  

                                                                               

         

                   

                                                                  

             

                                                          

                                   

                           

                             

                                                                             

                                                                                     

            

                                                         

                          

                                               

                     

                                 

                                      

                                                    

   

   

        

   

                                                                                

                                                             

               

                               

                                                       

                     

                                                       

                                   

                   

         

              

               

                             

                                                                                          

                   

       

           

           

         

           

           

           

           

             

           

             

               

             

           

           

           

           

               

           

                                         

                                   

                                     

                                                     

                   

                     

                    

                                           

                                                                                                       

   

     

                       

                                                                 

                                                       

                                                         

                                                                       

     

     

         

     

                 

                                                       

   

                           

                                                                           

                     

                                                                       

                                                                     

                     

                       

                         

                       

                             

                                         

                       

     

   

                           

                                                                           

                     

                                                                           

                               

                                                         

                                                                                                       

     

                                                                       

                                                                                                           

   

   

                                                                 

     

     

         

   

                           

                                           

     

                         

       

                       

             

                                             

                                           

                                           

   

                                                     

                                                                                 

   

                     

                               

                             

   

                   

                                 

                                 

   

                                               

         

           

               

                                 

                                                                                                         

                                                     

   

           

                         

               

                                 

   

                 

                                           

                       

   

     

     

           

   

                                        

      

                        

                                

                                                                                  

                                                                                                          

    

                                                                                                              

      

      

            

    

                                        

      

                        

                                

                            

              

                    

                                                                              

                                                                    

                                                                  

                                

                                                                                                              

      

      

            

    

                                        

      

                        

                                                

                            

                  

                    

      

      

            

    

                                        

      

                        

                                                

                            

                  

              

                                      

                              

      

      

      

                  

   

                         

                                                                                                 

     

                                               

                    

                                                            

                                                    

                                                  

   

                  

                                                                                                            

                      

                    

                

                          

                    

                                        

                                                            

                                

                                                                                            

                                                                                                    

    

                                                                                                        

        

    

      

    

   

                                

                                  

                            

                                                                                                        

    

      

   

                                                                    

    

     

               

                                                                                                          

             

                                 

                      

                          

                           

                                             

              

        

   

                                                                                            

                                              

                                

                                                                                     

                                                                     

                                                                                     

相关文章:

K8S学习教程(三):在PetaExpress KubeSphere 容器部署 Wiki 系统 wiki.js 并启用中文全文检索

背景 wiki.js 是非常优秀的开源 Wiki 系统&#xff0c;尽管在与 xwiki 功能相比 &#xff0c;还不算完善&#xff0c;但也在不断进步。 常用的功能还是比较实用的&#xff0c;如&#xff1a;Wiki 写 作、分享、权限管理功能还是非常实用的&#xff0c;UI 设计非常的漂亮&#x…...

服务器该如何抵御CC攻击

CC攻击也是分布式拒绝服务攻击的一种类型&#xff0c;同时CC攻击也属于网络流量攻击&#xff0c;但是CC攻击主要是用来攻击网站页面的&#xff0c;向着目标网络服务器发送一些请求&#xff0c;以此来消耗目标网络服务器的资源&#xff0c;导致目标服务器无法响应正常请求&#…...

关于centos7自带的nginx1.20.1开启https后,XP系统的IE6和IE8无法显示网页的问题

CentOS7自带的nginx-1.20.1是支持HTTP/2和TLS1.3的。 软件包名称&#xff1a;nginx-1.20.1-10.el7.x86_64 CentOS7默认开启了HTTP/2&#xff0c;但没有开启TLS1.3&#xff0c;以及IE6和IE8的https访问。 开启方法&#xff1a; ssl_ciphers HIGH:!aNULL:!MD5;改为ssl_ciphers…...

Zotero软件翻译插件Translate for Zotero的API接入方法--百度垂直领域翻译

首先注册通用文本翻译API的token:百度翻译开放平台 (baidu.com)&#xff08;可以免费认证 升级为高级版&#xff09; 之后点击管理控制台&#xff0c;选择总览右侧最下方可以看到个人的id和密码 点击文档与支持&#xff0c; 在这里可以选择领域。 支持传入值描述支持语言方向…...

python实现接口自动化

代码实现自动化相关理论 代码编写脚本和工具实现脚本区别是啥? 代码&#xff1a; 优点&#xff1a;代码灵活方便缺点&#xff1a;学习成本高 工具&#xff1a; 优点&#xff1a;易上手缺点&#xff1a;灵活度低&#xff0c;有局限性。 总结&#xff1a; 功能脚本&#xff1a;工…...

如何提问 如何回答

如何提问 如何回答 如何提出一个好问题 1、选择合适的平台或专家&#xff1a;选择合适的论坛&#xff0c;或者能够给你答案的地方或者人 2、清晰描述问题背景&#xff1a;描述问题的背景&#xff0c;清楚明确地表达你的问题以及需求&#xff0c;不需要加过多的语气助词&#…...

计算机图形学入门26:高级光线传播

1.有偏与无偏 在做光线追踪很多方法都是用蒙特卡洛积分去估计&#xff0c;蒙特卡洛积分有些是无偏的(Unbiased)&#xff0c;所谓无偏估计就是无论使用多少个样品&#xff0c;所估计的期望值都是正确的。那么&#xff0c;所有其他情况都是有偏的(Biased)&#xff0c;就是估计的期…...

STM32蓝牙HID实战:打造低功耗、高性能的客制化键盘

一、项目概述 本项目旨在使用STM32单片机打造一款功能强大的蓝牙客制化键盘&#xff0c;它拥有以下特点&#xff1a; 九键布局&#xff0c;小巧便携: 满足日常使用需求&#xff0c;方便携带。全键可编程: 所有按键和旋钮均可通过电脑软件自定义快捷键&#xff0c;实现个性化功…...

C++ STL容器:序列式容器-队queue,deque

摘要&#xff1a; CC STL&#xff08;Standard Template Library&#xff0c;标准模板库&#xff09;在C编程中的重要性不容忽视&#xff0c;STL提供了一系列容器、迭代器、算法和函数对象&#xff0c;这些组件极大地提高了C程序的开发效率和代码质量。 STL 容器 分为 2 大类 …...

简谈设计模式之单例模式

上一篇博客已经介绍了设计模式及其设计原则, 在这篇博客中笔者会介绍一下单例模式, 也是最简单的一种设计模式 单例模式 单例模式属于创建型模式. 它涉及到一个单一的类, 该类负责创建自己的对象, 同时确保只有单个对象被创建, 这个类提供了一种访问其唯一对象的方式, 可以直…...

在Spring Boot中实现多线程任务调度

在Spring Boot中实现多线程任务调度 大家好&#xff0c;我是微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 1. Spring Boot中的任务调度 Spring Boot通过集成Spring框架的Task Execution和Scheduling支持&#xff0c;提供…...

dify/api/models/account.py文件中的数据表

源码位置&#xff1a;dify\api\models\account.py accounts 表结构 字段英文名数据类型字段中文名字备注idStringUUIDIDnameString名称emailString邮箱passwordString密码password_saltString密码盐avatarString头像interface_languageString界面语言interface_themeString界…...

SQLAlchemy迁移数据库

SQLAlchemy迁移数据库 目录 SQLAlchemy迁移数据库安装Alembic配置Alembic编辑 alembic.ini编辑env.py生成迁移文件建表语句示例修改迁移文件命名格式 安装Alembic pip install alembic配置Alembic 执行初始化后会创建一个 alembic 目录&#xff0c;包含Alembic的配置文件 ale…...

Django文档简化版——Django快速入门——创建一个基本的投票应用程序

Django快速入门——创建一个基本的投票应用程序 准备工作1、创建虚拟环境2、安装django 1、请求和响应&#xff08;1&#xff09;创建项目&#xff08;2&#xff09;用于开发的简易服务器&#xff08;3&#xff09;创建投票应用&#xff08;4&#xff09;编写第一个视图1、编写…...

安全防御第三天(笔记持续更新)

1.接口类型以及作用 接口 --- 物理接口 三层口 --- 可以配置IP地址的接口 二层口 普通二层口 接口对 --- “透明网线” --- 可以将一个或者两个接口配置成为接口对&#xff0c;则 数据从一个接口进&#xff0c;将不需要查看MAC地址表&#xff0c;直接从另一个接口出&#xff1b…...

【12321骚扰电话举报受理中心-短信验证安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…...

杂项——循迹模块调节方法

1-4 路灰度传感器的调节方法&#xff1a; 调节时探头应对着颜色较浅的上方&#xff08;如果是黑白线赛道则应该将探头 对着白色上方调&#xff09;&#xff0c;轻轻的将全部可调电阻顺时针拧到底&#xff0c;再逆时针 慢慢回旋&#xff0c;直到对应探头的信号指示灯亮起后&…...

揭秘:源代码防泄密的终极秘籍

在当今信息科技高度发达的时代&#xff0c;源代码作为企业最核心的资产之一&#xff0c;其安全性不言而喻。源代码的泄露可能导致企业技术机密被竞争对手获取&#xff0c;进而威胁到企业的市场竞争力和长远发展。因此&#xff0c;源代码防泄密成为了企业信息安全工作的重中之重…...

avcodec_send_packet函数阻塞

用ffmpeg4.1.4开发一个播放器&#xff0c;解码过程如下&#xff0c;在每个函数前设置标志&#xff0c;测试发现程序阻塞在avcodec_send_packet函数。 while(true){av_read_frameavcodec_send_packetavcodec_receive_frameav_packet_unref } 解释如下&#xff1a; avcodec_se…...

一个parquet-go例子

一个parquet-go例子 使用go读写parquet&#xff0c;使用到了框架github.com/xitongsys/parquet-go 代码: package mainimport ("log""time""github.com/xitongsys/parquet-go-source/local""github.com/xitongsys/parquet-go/parquet&qu…...

扩散模型笔记

长参数“T”决定了生成全噪声图像所需的步长。在本文中&#xff0c;该参数被设置为1000&#xff0c;这可能显得很大。我们真的需要为数据集中的每个原始图像创建1000个噪声图像吗?马尔可夫链方面被证明有助于解决这个问题。由于我们只需要上一步的图像来预测下一步&#xff0c…...

上海-LM科技(面经)

上海-LM科技 hr电话面 个人简介 个人信息的询问 是否知道芋道框架 技术面 算法题 14. 最长公共前缀&#xff08;写出来即可&#xff09; 聊一下Docker Docker核心概念总结Docker实战 聊一下AOP Spring AOP详解 聊一下JWT JWT 基础概念详解JWT 身份认证优缺点分析 Spring…...

用 Echarts 画折线图

https://andi.cn/page/621503.html...

C++的map / multimap容器

一、介绍 在C的map / multimap容器中&#xff0c;所有的元素均是pair类型&#xff08;有关pair类型可以参考我之前写的 《C的set / multiset容器》的3.2中有介绍到&#xff09;。 每对pair的第一个元素被称为关键字key&#xff0c;第二个元素被称为值value。因此&#xff0c;ma…...

双向链表 -- 详细理解和实现

欢迎光顾我的homepage 前言 双向链表是一种带头双向循环的链表。在双向链表中&#xff0c;首先存在着一个头结点&#xff1b;其次每个节点有指向下一个节点的指针next 和指向上一个节点的指针prev &#xff1b…...

WebGIS面试题

文章目录 1. 前端1.1. 选择器的优先级1.2. CSS 中它的布局有哪些&#xff1f;1.3. CSS3 的新特性1.4. CSS 的两种盒子模型1.5. CSS 的伪元素选择器和伪类选择器有哪些&#xff1f;1.6. ES6 的新特性1.7. 谈谈你对 promise 的理解1.8. 简单说一下原型链1.9. 简单说一下深浅拷贝1…...

代码随想录算法训练营:21/60

非科班学习算法day21 | LeetCode669:修剪二叉搜索树 &#xff0c;Leetcode108:将有序数组转换为二叉搜索树 &#xff0c;Leetcode538:把二叉搜索树转换为累加树 介绍 包含LC的两道题目&#xff0c;还有相应概念的补充。 相关图解和更多版本&#xff1a; 代码随想录 (progra…...

数据结构——二叉树之c语言实现堆与堆排序

目录 前言&#xff1a; 1.二叉树的概念及结构 1.1 特殊的二叉树 1.2 二叉树的存储结构 1.顺序存储 2.链式存储 2. 二叉树的顺序结构及实现 2.1 堆的概念 ​编辑 2.2 堆的创建 3.堆的实现 3.1 堆的初始化和销毁 初始化&#xff1a; 销毁&#xff1a; 插入&…...

#数据结构 链表

单向链表 1. 概念 单向链表 单向循环链表 双向链表 双向循环链表 解决&#xff1a;长度固定的问题&#xff0c;插入和删除麻烦的问题 1、逻辑结构&#xff1a; 线性结构 2、存储结构&#xff1a; 链式存储 链表就是将 结点 用链串起来的线性表&#xff0c;链就是 结点 中的…...

单片机软件架构连载(4)-结构体

枚举、指针、结构体&#xff0c;我愿称为C语言"三板斧"。 用人话来讲&#xff0c;几乎所有c语言高阶编程&#xff0c;都离不开这这3个知识点的应用。 今天站在实际产品常用的角度&#xff0c;给大家讲一下结构体。 1.结构体概念 结构体可以用来构建更复杂的数据结…...