开发缘由
- 官方网页存在经常中途断开的问题.
- 经常使用不同
ip
登录openai
帐号可能会导致封号. - 使用开源项目
chatgpt-web
搭建过一个网页端,目前已被DNS污染, - 体验
GitHub Copilot
. - 已经使用了
rust
语言一段时间,打算用它写个服务端练手.
服务端
技术栈
- rust
Rust是一种系统级编程语言,由Mozilla开发。它的设计目标是提供一种安全、并发、实用的编程语言。Rust的语法类似于C++,但它具有内存安全和线程安全的特性,这使得它在编写高性能系统级代码时非常有用。Rust还有一个强大的包管理器Cargo,可以帮助开发者管理依赖项和构建项目。
- tokio
Tokio是一个基于Rust语言的异步运行时库,它提供了一种高效的方式来编写异步I/O应用程序。Tokio的核心是一个事件循环,它可以处理大量的并发连接,而不会消耗太多的系统资源。Tokio还提供了一组异步I/O原语,包括TCP、UDP、Unix域套接字、定时器等,这些原语可以帮助开发者编写高性能的网络应用程序。Tokio还提供了一些工具和宏,可以帮助开发者编写简洁、易于维护的异步代码。
- axum
Axum是一个基于Rust语言的Web框架,它使用了异步I/O和Tokio运行时来提供高性能的Web服务。Axum的设计目标是提供一种简单、易于使用的Web框架,同时保持高性能和可扩展性。Axum的核心是一个基于路由的处理器,它可以将HTTP请求路由到不同的处理器函数中。Axum还提供了一些中间件,可以用于处理请求和响应,例如身份验证、日志记录、错误处理等。Axum还提供了一些工具和宏,可以帮助开发者编写简洁、易于维护的Web应用程序。Axum的依赖管理使用Cargo,这使得开发者可以轻松地管理依赖项和构建项目。
- clap
Clap是一个基于Rust语言的命令行参数解析库,它提供了一种简单、易于使用的方式来解析命令行参数。Clap的设计目标是提供一种灵活、可定制的命令行解析器,同时保持高性能和易于使用。Clap支持各种类型的命令行参数,包括标志、选项、位置参数等。Clap还支持子命令,可以帮助开发者构建复杂的命令行工具。Clap的API文档非常详细,而且提供了大量的示例代码,这使得开发者可以快速上手并使用Clap来解析命令行参数。Clap的依赖管理使用Cargo,这使得开发者可以轻松地管理依赖项和构建项目。
- async-openai
async-openai是一个基于Rust语言的异步OpenAI API客户端库,它使用异步I/O和Tokio运行时来提供高性能的OpenAI API服务。async-openai的设计目标是提供一种简单、易于使用的方式来访问OpenAI API,同时保持高性能和可扩展性。async-openai支持各种类型的OpenAI API,包括文本生成、语言翻译、语言理解等。async-openai还提供了一些工具和宏,可以帮助开发者编写简洁、易于维护的异步代码。async-openai的依赖管理使用Cargo,这使得开发者可以轻松地管理依赖项和构建项目。
- anyhow
anyhow是一个基于Rust语言的错误处理库,它提供了一种简单、易于使用的方式来处理错误。anyhow的设计目标是提供一种灵活、可定制的错误处理机制,同时保持高性能和易于使用。anyhow的核心是一个Error类型,它可以包含任何类型的错误信息。anyhow还提供了一些工具和宏,可以帮助开发者编写简洁、易于维护的错误处理代码。anyhow的依赖管理使用Cargo,这使得开发者可以轻松地管理依赖项和构建项目。
- serde
serde是一个基于Rust语言的序列化和反序列化库,它提供了一种简单、易于使用的方式来将数据结构转换为字节流或从字节流中解析数据结构。serde的设计目标是提供一种灵活、可定制的序列化和反序列化机制,同时保持高性能和易于使用。serde支持各种类型的数据结构,包括基本类型、元组、数组、结构体、枚举等。serde还支持各种格式的数据序列化和反序列化,包括JSON、YAML、TOML、Bincode等。serde的API文档非常详细,而且提供了大量的示例代码,这使得开发者可以快速上手并使用serde来序列化和反序列化数据。serde的依赖管理使用Cargo,这使得开发者可以轻松地管理依赖项和构建项目。
- tracing
tracing是一个基于Rust语言的分布式应用程序跟踪系统,它提供了一种简单、易于使用的方式来跟踪应用程序中的事件和操作。tracing的设计目标是提供一种灵活、可定制的跟踪机制,同时保持高性能和易于使用。tracing支持各种类型的跟踪事件,包括日志记录、性能分析、错误处理等。tracing还提供了一些工具和宏,可以帮助开发者编写简洁、易于维护的跟踪代码。tracing的依赖管理使用Cargo,这使得开发者可以轻松地管理依赖项和构建项目。在Rust生态系统中,tracing是一个非常流行的跟踪库,被广泛用于构建高性能、可扩展的分布式应用程序。
服务端功能
-
隐私安全
配合客户端,不记录任何设备信息,未保存ip信息,不记录任何聊天记录,高度隐私. -
支持服务端指定
api_key
. -
支持客户端自定义
api_key
.服务端只做转发功能. -
自定义端口.
部分代码由GitHub Copilot
生成
用法
./openai_api_server -a "your_key" -p "your_port"
客户端
技术栈
- okhttp
- room
- jtokkit
用于token数计算 - lottie
动画展示 - openai-client
用于本地模式
部分代码由GitHub Copilot
生成,大部分图片由Stable Diffusion WebUI
生成.
客户端功能
- 自定义
api_key
. - 本地模式(使用自己
api_key
,从本地发出请求,不使用服务器转发) - 隐私安全.
聊天记录存本地,可删除. 不收集任何隐私信息. - 自定义最大token数.
- 自定义内容记录长度.
- 支持
prompts
客户端截图
服务端项目地址:https://github.com/tangxuesong6/kyf_server
客户端项目地址:https://github.com/tangxuesong6/kyf_client