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

开发个人Ollama-Chat--5 模型管理 (二)

开发个人Ollama-Chat–5 模型管理 (二)

ChatGPT

这是该项目的最终效果,使用ollamaopen-webui进行人与机器的对话功能,对话的后端服务则完全对接自己开发的Go项目。
chatgpt
如何实现呢?则通过这篇文章,一一给大家剖析后端的原理及功能实现。

ollama-go

请添加图片描述

根据上图结果,生成的stream响应,就可与open-webUI进行对话,实现ChatGPT的功能效果。

正片开始

文件目录:

├── chat
│   ├── api
│   │   ├── chat.api
│   │   ├── chat.go
│   │   ├── etc
│   │   │   └── chat.yaml
│   │   ├── go.mod
│   │   ├── go.sum
│   │   ├── internal
│   │   │   ├── config
│   │   │   ├── handler
│   │   │   ├── logic
│   │   │   ├── svc
│   │   │   └── types
│   │   ├── logs
│   │   │   ├── access.log
│   │   │   ├── error.log
│   │   │   ├── severe.log
│   │   │   ├── slow.log
│   │   │   └── stat.log
│   │   └── web
│   │       └── static
│   └── rpc
│       ├── chat
│       │   ├── chat_grpc.pb.go
│       │   └── chat.pb.go
│       ├── chatclient
│       │   └── chat.go
│       ├── chat.go
│       ├── chat.proto
│       ├── etc
│       │   └── chat.yaml
│       ├── go.mod
│       ├── go.sum
│       ├── internal
│       │   ├── config
│       │   ├── logic
│       │   ├── server
│       │   └── svc
│       └── logs
│           ├── access.log
│           ├── error.log
│           ├── severe.log
│           ├── slow.log
│           └── stat.log

5.1 生成 chat model 模型

  • 创建 chat.sql,生成chat相关数据表。字段不可缺少任意一个,否则open-webui无法正常展示

    CREATE TABLE `chat` (`id` bigint unsigned NOT NULL AUTO_INCREMENT,`user_id` varchar(255)  NOT NULL DEFAULT '' COMMENT '用户ID',`title` varchar(255)  NOT NULL DEFAULT '' COMMENT '标题',`chat` longtext  NOT NULL COMMENT '',`archived` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '',`share_id` varchar(255)  NOT NULL DEFAULT '' COMMENT '分享用户ID',`create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP,`update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`id`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4;
    
  • 创建prompt.sql,生成prompt相关数据表。字段不可缺少任意一个,否则open-webui无法正常展示

    drop table if exists prompt;
    CREATE TABLE `prompt` (`id` bigint unsigned NOT NULL AUTO_INCREMENT,`command` varchar(255)  NOT NULL DEFAULT '' COMMENT '命令',`user_id` varchar(255)  NOT NULL DEFAULT '' COMMENT '用户ID',`title` varchar(255)  NOT NULL DEFAULT '' COMMENT '标题',`content` longtext  NOT NULL COMMENT '文本',`create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP,`update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,PRIMARY KEY (`id`),UNIQUE KEY `command` (`command`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4;
    
  • 运行模板生成命令 model文件放置在通用目录,和go-zero官方案例不同

    # chat model
    goctl model mysql ddl -src ./model/chat.sql -dir ./model -c# prompt model
    goctl model mysql ddl -src ./model/prompt.sql -dir ./model -c
    

5.2 生成 chat api 服务

前缀,路由,传参,响应不可变,否则 openui调用失败

  • 创建 chat.api 文件

    type (// 产品创建CreateRequest {UserId   string `json:"userId"`Title    string `json:"title"`Chat     string `json:"chat"`ShareId  string `json:"shareId"`Archived int64  `json:"archived"`}CreateResponse {Id int64 `json:"id"`}// 产品创建// 产品修改UpdateRequest {Chat string `json:"chat"`}UpdateResponse  {}// 产品修改// 产品删除RemoveRequest {Id int64 `json:"id, optional"`}RemoveResponse  {}// 产品删除// 产品详情DetailRequest {Id int64 `json:"id, optional"`}DetailResponse {Id       int64  `json:"id"`UserId   string `json:"userId"`Title    string `json:"title"`Chat     string `json:"chat"`ShareId  string `json:"shareId"`Archived int64  `json:"archived"`}// 产品详情ListRequest  {}// 数组 产品详情ListResponse {Data []DetailResponse `json:"data"`}VersionResponse {Version string `json:"version"`}ChangelogResponse {Changelog string `json:"changelog"`}ConfigResponse {Status                   bool                       `json:"status"`Name                     string                     `json:"name"`Version                  string                     `json:"version"`DefaultLocale            string                     `json:"default_locale"`Images                   bool                       `json:"images"`DefaultModels            interface{}                `json:"default_models"`DefaultPromptSuggestions []DefaultPromptSuggestions `json:"default_prompt_suggestions"`TrustedHeaderAuth        bool                       `json:"trusted_header_auth"`}DefaultPromptSuggestions {Title   []string `json:"title"`Content string   `json:"content"`}ModelReponse {Models []ModelDetail `json:"models"`}ModelDetail {Id         string  `json:"id"`Name       string  `json:"name"`Model      string  `json:"model"`ModifiedAt string  `json:"modified_at"`Size       int64   `json:"size"`Digest     string  `json:"digest"`Details    Details `json:"details"`}Details {Format            string      `json:"format"`Family            string      `json:"family"`Families          interface{} `json:"families"`ParameterSize     string      `json:"parameter_size"`QuantizationLevel string      `json:"quantization_level"`}Prompt {Id      int64  `json:"id"`Command string `json:"command"`UserId  string `json:"user_id"`Title   string `json:"title"`Content string `json:"content"`}PromptResponse {Prompts []Prompt `json:"prompts"`}DefaultModels {Models string `json:"models"`}Chat {ID        string `json:"id"`Title     string `json:"title"`UpdatedAt int    `json:"updated_at"`CreatedAt int    `json:"created_at"`}ChatMessage {Chats Chat `json:"chats"`}NewChatRequest {Chat ChatEntity `json:"chat"`}ChatEntity {Id        string                   `json:"id"`Title     string                   `json:"title"`Models    []string                 `json:"models"`Options   map[string]interface{}   `json:"options,optional"`Messages  []map[string]interface{} `json:"messages,optional"`History   map[string]interface{}   `json:"history,optional"`Tags      []map[string]interface{} `json:"tags,optional"`Timestamp int64                    `json:"timestamp"`}// new chatNewChatEntity {Model    string           `json:"model"`Messages []MessagesEntity `json:"messages"`Options  OptionsEntity    `json:"options"`}MessagesEntity {Role    string `json:"role"`Content string `json:"content"`}OptionsEntity  {}ChatRespone {Text string `json:"text"`}UpdateChatRequest {Chat UpdateChat `json:"chat"`}UpdateChat {Messages []UpdateMessages `json:"messages, optional"`History  UpdateHistory    `json:"history, optional"`}UpdateMessages {Id          string   `json:"id"`ChildrenIds []string `json:"childrenIds"`Role        string   `json:"role"`Content     string   `json:"content"`Timestamp   int64    `json:"timestamp"`}UpdateHistory {Messages  map[string]interface{} `json:"messages"`CurrentId string                 `json:"currentId"`}CompleteRequest {Model    string           `json:"model"`Messages []MessagesEntity `json:"messages"`Stream   bool             `json:"stream"`}
    )@server (jwt: Auth
    )
    service Chat {@handler Versionget /ollama/api/version returns (VersionResponse)@handler OllTagsget /ollama/api/tags returns (ModelReponse)@handler Chatpost /ollama/api/chat (NewChatEntity) returns (ChatRespone)@handler Completepost /ollama/v1/chat/completions (CompleteRequest) returns (ChatRespone)
    }service Chat {@handler Changelogget /api/changelog returns (ChangelogResponse)@handler Configget /api/config returns (ConfigResponse)
    }@server (jwt:    Authprefix: /api/v1
    )
    service Chat {@handler GetPromptget /prompts returns (PromptResponse)@handler GetDefaultModelspost /configs/default/models (DefaultModels) returns (DefaultModels)
    }@server (jwt:    Authprefix: /api/v1
    )
    service Chat {@handler Createpost /chats/new (NewChatRequest) returns (CreateResponse)@handler Updatepost /chats/:id (UpdateChatRequest) returns (UpdateResponse)@handler Removedelete /chats/:id (RemoveRequest) returns (RemoveResponse)@handler Listget /chats (ListRequest) returns ([]Chat)@handler Detailget /chats/:id (DetailRequest) returns (DetailResponse)
    }
  • 运行模板生成命令

    goctl api go -api ./api/chat.api -dir ./api
    

5.3 生成 user rpc 服务

  • 创建 chat.proto文件

    syntax = "proto3";package chat;option go_package = "./chat";message Empty {
    }
    // 产品创建
    message CreateRequest {string UserId = 1;string Title = 2;string Chat = 3;string ShareId = 4;int64 Archived = 5;
    }
    message CreateResponse {int64 Id = 1;
    }
    // 产品创建// 产品修改
    message UpdateRequest {int64 Id = 1;string UserId = 2;string Title = 3;string Chat = 4;string ShareId = 5;int64 Archived = 6;
    }
    message UpdateResponse {
    }
    // 产品修改// 产品删除
    message RemoveRequest {int64 Id = 1;
    }
    message RemoveResponse {
    }
    // 产品删除// 产品详情
    message DetailRequest {int64 Id = 1;
    }
    message DetailResponse {int64 Id = 1;string UserId = 2;string Title = 3;string Chat = 4;string ShareId = 5;int64 Archived = 6;
    }
    // 产品详情message ListChats {repeated DetailResponse List = 1;
    }// 调用ollama 大模型
    message CallRequest {string Name = 1;string Prompt = 2;string Role = 3;
    }message CallResponse {string Text = 1;
    }message Prompt {int64 Id = 1;string Command = 2;string Title = 3;string UserId = 4;string Content = 5;
    }message ListPrompts{repeated Prompt List = 1;
    }message NewChatEntity {string Model = 1;repeated MessagesEntity Messages = 2;OptionsEntity Options = 3;
    }message MessagesEntity {string Role = 1;string Content = 2;
    }message OptionsEntity {}service Chat {rpc Create(CreateRequest) returns(CreateResponse);rpc Update(UpdateRequest) returns(UpdateResponse);rpc Remove(RemoveRequest) returns(RemoveResponse);rpc Detail(DetailRequest) returns(DetailResponse);rpc ListChat(Empty) returns(ListChats);rpc ListPrompt(Empty) returns(ListPrompts);rpc Call(CallRequest) returns(CallResponse);rpc GenPrompt(NewChatEntity) returns(CallResponse);
    }
    
  • 运行模板生成命令

    goctl rpc protoc ./rpc/chat.proto --go_out=./rpc/types --go-grpc_out=./rpc/types --zrpc_out=./rpc
    

5.4 配置文件

  • rpc/etc

    Name: chat.rpc
    ListenOn: 0.0.0.0:9002Etcd:Hosts:- ******:2379Key: chat.rpcTimeout: 0Mysql:Host: ******Port: 3309DbName: openuiUser: rootPassword: "**********"DBZone: "TS"Charset: utf8mb4MaxIdle: 10MaxOpen: 100LogMode: trueLoc: Asia/ShanghaiDebug: trueTablePrefix: "v1_"MaxLifetime: 300CacheRedis:Name: "openui"Nettype: "tcp"Address: "******:6379"Auth: ""DB: 0Salt: ******#日志配置
    LogConf:ServiceName: chat.rpcMode: fileTimeFormat: 2006-01-02 15:04:05.000Path: logsLevel: infoCompress: trueStat: false # 不记录CPU、内存等信息KeepDays: 10MaxBackups: 2
    
  • api/etc

    Name: Chat
    Host: 0.0.0.0
    Port: 8082Mysql:Host: **********Port: 3309DbName: openuiUser: rootPassword: "**********"DBZone: "TS"Charset: utf8mb4MaxIdle: 10MaxOpen: 100LogMode: trueLoc: Asia/ShanghaiDebug: trueTablePrefix: "v1_"MaxLifetime: 300Timeout: 0CacheRedis:Name: "openui"Nettype: "tcp"Address: "**********:6379"Auth: ""DB: 0Auth:AccessSecret: **********AccessExpire: 86400#日志配置
    LogConf:ServiceName: chat.apiMode: fileTimeFormat: 2006-01-02 15:04:05.000Path: logsLevel: infoCompress: trueStat: false # 不记录CPU、内存等信息KeepDays: 10MaxBackups: 2ChatRpc:Etcd:Hosts:- **********:2379Key: chat.rpcOllUrl: http://**********:11434
    

5.5 业务处理

  • 业务处理就不过多描述了,具体处理流程可以看相应文件的实现

项目地址

jackwillsmith/openui-svelte-build (github.com)

GitHub - jackwillsmith/openui-backend-go: openui-backend-go

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Java数据结构-链表与LinkedList
  • 触摸屏虚拟键盘组件 jQuery Virtual Keyboard使用 自定义键盘
  • 阿里巴巴矢量图标库使用
  • 梯度下降算法的原理
  • allWebPlugin中间件实现ActiveX插件在谷歌、火狐、Edge浏览器使用
  • C++:从C语言过渡到C++
  • C++:C++入门基础|命名空间|输入输出
  • OSS存储桶密钥泄露【案例】
  • 【基于R语言群体遗传学】-14-种群起源的相对似然
  • 【云原生】AWS云平台,ECR推送Helm chart包
  • TCP/IP协议超时重传,以及应用层超时重传一文详解
  • OpenHarmony 入门——ArkUI自定义组件的基础语法(一)
  • 开源项目的认识理解
  • 深度学习中的超参管理方法:argparse模块
  • Nodejs 第八十六章(部署pm2)
  • .pyc 想到的一些问题
  • [ JavaScript ] 数据结构与算法 —— 链表
  • 2019年如何成为全栈工程师?
  • Date型的使用
  • golang 发送GET和POST示例
  • Java程序员幽默爆笑锦集
  • Java知识点总结(JDBC-连接步骤及CRUD)
  • Laravel 菜鸟晋级之路
  • sublime配置文件
  • Webpack4 学习笔记 - 01:webpack的安装和简单配置
  • 缓存与缓冲
  • 记一次用 NodeJs 实现模拟登录的思路
  • 扫描识别控件Dynamic Web TWAIN v12.2发布,改进SSL证书
  • 线性表及其算法(java实现)
  • Android开发者必备:推荐一款助力开发的开源APP
  • PostgreSQL之连接数修改
  • 新海诚画集[秒速5センチメートル:樱花抄·春]
  • #### golang中【堆】的使用及底层 ####
  • (C语言)fgets与fputs函数详解
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (Redis使用系列) Springboot 实现Redis消息的订阅与分布 四
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (笔试题)分解质因式
  • (附源码)springboot人体健康检测微信小程序 毕业设计 012142
  • (附源码)流浪动物保护平台的设计与实现 毕业设计 161154
  • (十一)JAVA springboot ssm b2b2c多用户商城系统源码:服务网关Zuul高级篇
  • (一) 初入MySQL 【认识和部署】
  • (转)shell中括号的特殊用法 linux if多条件判断
  • .babyk勒索病毒解析:恶意更新如何威胁您的数据安全
  • .NET 的程序集加载上下文
  • .NET 回调、接口回调、 委托
  • .NET周刊【7月第4期 2024-07-28】
  • .sh文件怎么运行_创建优化的Go镜像文件以及踩过的坑
  • @RequestMapping-占位符映射
  • [ Linux ] git工具的基本使用(仓库的构建,提交)
  • [android] 天气app布局练习
  • [BSGS算法]纯水斐波那契数列
  • [Bugku]密码???[writeup]
  • [C# 开发技巧]如何使不符合要求的元素等于离它最近的一个元素
  • [codevs 1515]跳 【解题报告】