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

news2024/9/20 23:42:41

开发个人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 chat
    	NewChatEntity {
    		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 Version
    	get /ollama/api/version returns (VersionResponse)
    
    	@handler OllTags
    	get /ollama/api/tags returns (ModelReponse)
    
    	@handler Chat
    	post /ollama/api/chat (NewChatEntity) returns (ChatRespone)
    
    	@handler Complete
    	post /ollama/v1/chat/completions (CompleteRequest) returns (ChatRespone)
    }
    
    service Chat {
    	@handler Changelog
    	get /api/changelog returns (ChangelogResponse)
    
    	@handler Config
    	get /api/config returns (ConfigResponse)
    }
    
    @server (
    	jwt:    Auth
    	prefix: /api/v1
    )
    service Chat {
    	@handler GetPrompt
    	get /prompts returns (PromptResponse)
    
    	@handler GetDefaultModels
    	post /configs/default/models (DefaultModels) returns (DefaultModels)
    }
    
    @server (
    	jwt:    Auth
    	prefix: /api/v1
    )
    service Chat {
    	@handler Create
    	post /chats/new (NewChatRequest) returns (CreateResponse)
    
    	@handler Update
    	post /chats/:id (UpdateChatRequest) returns (UpdateResponse)
    
    	@handler Remove
    	delete /chats/:id (RemoveRequest) returns (RemoveResponse)
    
    	@handler List
    	get /chats (ListRequest) returns ([]Chat)
    
    	@handler Detail
    	get /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:9002
    
    Etcd:
        Hosts:
            - ******:2379
        Key: chat.rpc
    
    Timeout: 0
    
    Mysql:
        Host: ******
        Port: 3309
        DbName: openui
        User: root
        Password: "**********"
        DBZone: "TS"
        Charset: utf8mb4
        MaxIdle: 10
        MaxOpen: 100
        LogMode: true
        Loc: Asia/Shanghai
        Debug: true
        TablePrefix: "v1_"
        MaxLifetime: 300
    
    CacheRedis:
        Name: "openui"
        Nettype: "tcp"
        Address: "******:6379"
        Auth: ""
        DB: 0
    
    Salt: ******
    
    #日志配置
    LogConf:
        ServiceName: chat.rpc
        Mode: file
        TimeFormat: 2006-01-02 15:04:05.000
        Path: logs
        Level: info
        Compress: true
        Stat: false # 不记录CPU、内存等信息
        KeepDays: 10
        MaxBackups: 2
    
  • api/etc

    Name: Chat
    Host: 0.0.0.0
    Port: 8082
    
    Mysql:
        Host: **********
        Port: 3309
        DbName: openui
        User: root
        Password: "**********"
        DBZone: "TS"
        Charset: utf8mb4
        MaxIdle: 10
        MaxOpen: 100
        LogMode: true
        Loc: Asia/Shanghai
        Debug: true
        TablePrefix: "v1_"
        MaxLifetime: 300
    
    Timeout: 0
    
    CacheRedis:
        Name: "openui"
        Nettype: "tcp"
        Address: "**********:6379"
        Auth: ""
        DB: 0
    
    Auth:
        AccessSecret: **********
        AccessExpire: 86400
    
    #日志配置
    LogConf:
        ServiceName: chat.api
        Mode: file
        TimeFormat: 2006-01-02 15:04:05.000
        Path: logs
        Level: info
        Compress: true
        Stat: false # 不记录CPU、内存等信息
        KeepDays: 10
        MaxBackups: 2
    
    ChatRpc:
        Etcd:
            Hosts:
                - **********:2379
            Key: chat.rpc
    
    OllUrl: http://**********:11434
    

5.5 业务处理

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

项目地址

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1921979.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【进阶篇-Day8:JAVA中递归、异常的介绍】

目录 1、递归的介绍和使用1.1 递归的介绍1.2 案例案例一:案例二:案例三:案例四: 1.3 总结 2、异常的介绍和使用2.1 异常的介绍:(1)能够看懂异常(2)异常的体系接口和分类&…

fortran快速排序算法,示例对一维数组进行排序

fortran快速排序算法,示例对一维数组进行排序 0. 引言1. 快速排序方法(QuickSqrt)代码实现2. 结语 0. 引言 快速排序(QuickSort)是一种常用的排序算法,采用分治策略实现。它的基本思想是通过一趟排序将待排序的数据分割成独立的两…

[笔试训练](三十六)106:提取不重复的整数107:哈夫曼编码108:abb

目录 106:提取不重复的整数 107:哈夫曼编码 108:abb 106:提取不重复的整数 题目链接:提取不重复的整数_牛客题霸_牛客网 (nowcoder.com) 题目: ​ 题解: #include <iostream> #include <string> using namespace std; int n0; int cnt[10]; int ret0; int mai…

MySQL CONCAT函数的简单使用

CONCAT函数用于将mysql中查询多列的值拼成一列显示&#xff0c; 使用示例&#xff1a; SELECT CONCAT(attr_name,"&#xff1a;",attr_value) FROM pms_sku_sale_attr_value WHERE sku_id1; 上面SQL语句使用CONCAT函数将attr_name、attr_value两列的值拼成一列&am…

【代码随想录】【算法训练营】【第62天】 [卡码108]冗余连接 [卡码109]冗余连接II

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 卡码网。 day 62&#xff0c;又是一个周一&#xff0c;ding~ 题目详情 [卡码108] 冗余连接 题目描述 卡码108 冗余连接 LeetCode类似题目684 冗余连接 解题思路 前提&#xff1a; 思路&#xff1a; 重点&a…

如何对odoo17网站cookies进行配置(How to configure cookies for Odoo 17 website?)

浏览器cookies具有缓存和加速的作用&#xff0c;odoo17 website 模块内置了cookies的选项: &#xff08;Browser cookies have the function of caching and acceleration, and the Odoo 17 website module has built-in options for cookies:&#xff09; 1、安装website模块后…

TCP传输控制协议

传输控制协议&#xff08;TCP&#xff0c;Transmission Control Protocol&#xff09;是一种面向连接的、可靠的、基于字节流的传输层通信协议&#xff0c;由IETF的RFC 793[1]定义。 TCP旨在适应支持多网络应用的分层协议层次结构。 连接到不同但互连的计算机通信网络的主计算机…

【C++】哈希表的模拟实现及 unordered_set 和 unorderded_map 的封装

目录 前言一、哈希表的模拟实现1.1 哈希表的改造1.1.1 模板参数列表的改造1.1.2 增加迭代器操作 1.2 哈希表的模拟实现1.2.1 哈希表中仿函数的实现1.2.2 哈希表中节点类的实现1.2.3 哈希表中迭代器类的实现1.2.4 哈希表中构造函数、析构函数和 Clear() 函数的实现1.2.5 哈希表中…

JZ62 孩子们的游戏(圆圈中最后剩下的数)

题目来源&#xff1a;牛客 题目描述&#xff1a; 每年六一儿童节&#xff0c;牛客都会准备一些小礼物和小游戏去看望孤儿院的孩子们。其中&#xff0c;有个游戏是这样的&#xff1a;首先&#xff0c;让 n 个小朋友们围成一个大圈&#xff0c;小朋友们的编号是0~n-1。然后&…

Git 课程任务

** ** https://github.com/InternLM/Tutorial/pull/905 https://github.com/onlyzer0/all_you_need/blob/main/README.md

Dify中固定递归字符文本分割器的chunk长度计算方式

本文主要从源码角度剖析了Dify中FixedRecursiveCharacterTextSplitter的chunk长度计算方式。 1.self._length_function(chunk) 源码位置:dify\api\core\splitter\fixed\_text\_splitter.py\FixedRecursiveCharacterTextSplitter类\split\_text方法\self.\_length\_function(…

实验9 存储过程与函数的创建管理实验

一、实验目的&#xff1a; 理解存储过程和函数的概念。掌握创建存储过程和函数的方法。掌握执行存储过程和函数的方法。掌握游标的定义、使用方法。 二、实验内容 1&#xff0e;某超市的食品管理的数据库的Food表&#xff0c;Food表的定义如表所示&#xff0c; Food表的定义…

GESP 2023年12月C++二级真题

参考程序1&#xff1a; #include<iostream> using namespace std;int first,second; int m,n; int sum 0;int fn(int n) {if(n1) {return first;} else if (n2) {return second;} else {return fn(n-1)fn(n-2);} } int main() {cin>>first>>second;cin>…

【Golang】map的使用

map声明的方式 //声明var m map[string]string//在使用map之前&#xff0c;先make&#xff0c;make的作用就是给map分配空间m make(map[string]string)m["lover"] "Yzx"m["friend1"] "Zxw"m["friend2"] "Zzc"…

【电子通识】什么是无源元件的认证用可靠性试验标准AEC-Q200?

目前电动汽车已经是一个大趋势&#xff0c;汽车上安装有由多个电子零部件构成的ECU&#xff08;电子控制单元&#xff09;。即使汽车在恶劣的环境下行驶&#xff0c;电子零部件也必须不出故障地正常工作。因此&#xff0c;车载电子零部件与消费类电子相比&#xff0c;要求其达到…

Idea调试Kotlin代码

1.配置java虚拟机jvm远程调试 例如 启动程序配置 java -agentlib:jdwptransportdt_socket,servery,suspendn,address127.0.0.1:5005 -jar KtTest.jar IDEA配置远程调试JVM idea编译的Kt代码为 // IntelliJ API Decompiler stub source generated from a class file // Im…

人工智能是帮助开发人员还是取代他们?

最近&#xff0c;神经网络已经成为应用开发中不可或缺的工具。它们大大简化和加速了这一过程。 例如&#xff0c;使用GitHub Copilot&#xff0c;可以根据任务描述自动生成重复的代码部分。神经网络可以创建和运行测试&#xff0c;识别错误&#xff0c;甚至提出修复错误的方法…

数据库管理软件Navicat Premium介绍

1、点击连接 2、主界面 3、软件版本 待续...

【ZYNQ】VDMA 的使用

VDMA, Video Direct Memory Access 是 Xilinx 官方提供的高速内存存取 IP,采用 AXI4-Stream 与 AXI4 协议实现存储映射接口(Memory Map)与非存储映射接口(Non-Memory Map)接口的转换,主要用于视频数据缓存,同时提供帧缓存与帧同步控制功能。本文主要介绍 AXI VDMA 的配置…

博客文章多平台发布工具

做过博客分享和自媒体的同学应该都知道&#xff0c;在多个平台上同步发布、更新自己的原创内容&#xff0c;是快速传播知识、提高用户触达率的有效方式。 然而&#xff0c;一篇文章要在N个平台上重复进行编辑、排版、图片/视频上传的苦恼&#xff0c;你一定经历过吧&#xff1…