Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yokingma/search_with_ai
🤖 Free Search with AI, 💡 Open-Source Perplexity, 📍 Support Ollama/SearXNG, Support Docker deployment. 让AI大模型和搜索引擎回答你的问题,支持本地大模型(Ollama)、聚合搜索引擎SearXNG,支持Docker一键部署。
https://github.com/yokingma/search_with_ai
ai chatgpt free llm ollama perplexity rag search
Last synced: 1 day ago
JSON representation
🤖 Free Search with AI, 💡 Open-Source Perplexity, 📍 Support Ollama/SearXNG, Support Docker deployment. 让AI大模型和搜索引擎回答你的问题,支持本地大模型(Ollama)、聚合搜索引擎SearXNG,支持Docker一键部署。
- Host: GitHub
- URL: https://github.com/yokingma/search_with_ai
- Owner: yokingma
- License: mit
- Created: 2024-03-08T12:15:29.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-10-30T01:11:29.000Z (3 months ago)
- Last Synced: 2024-11-01T23:12:34.887Z (3 months ago)
- Topics: ai, chatgpt, free, llm, ollama, perplexity, rag, search
- Language: TypeScript
- Homepage: https://isou.chat
- Size: 9.22 MB
- Stars: 575
- Watchers: 9
- Forks: 126
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ChatGPT-repositories - search_with_ai - 🤖 Free Search with AI, 💡 Open-Source Perplexity, 📍 Support Ollama/SearXNG, Support Docker deployment. 让AI大模型和搜索引擎回答你的问题,支持本地大模型(Ollama)、聚合搜索引擎SearXNG,支持Docker一键部署。 (Langchain)
- StarryDivineSky - yokingma/search_with_ai
README
Build your conversation-based search with AI, a simple implementation with Node.js & Vue3.
**English** | [中文](./README_CN.md) | [日本語](./README_JP.md)
Repositories: [GitHub](https://github.com/yokingma/search_with_ai) [Gitee](https://gitee.com/zac_ma/search_with_ai) [CNB](https://cnb.cool/isou/AiSearch)
## Features
* Built-in support for LLM: OpenAI, Google, Lepton, DeepSeek, Ollama(local)
* Built-in support for search engine: Bing, Google, SearXNG(Free)
* Built-in support for web search plugin: ChatGLM
* Customizable pretty UI interface
* Support dark mode
* Support mobile display
* Support Ollama, [LMStudio](https://github.com/lmstudio-ai/lms)
* Support i18n
* Support Continue Q&A with contexts.
* Support Cache results, Force reload.
* Support images search.
* Support full web content extraction, based on [Jina](https://jina.ai/) Reader URL.## Deploy with Docker (recommended)
[Install Docker](https://docs.docker.com/install/).
> Project pre-built image [Docker Hub](https://hub.docker.com/r/zacma/aisearch/tags)1.**Get the code.**
```shell
git clone https://github.com/yokingma/search_with_ai.git
cd search_with_ai
```2.**Edit** [.env.docker](https://github.com/yokingma/search_with_ai/blob/main/.env) **file.** in ```deploy``` directory.
> After modifying the .env.docker file, restart the Docker container to apply changes.
You must set at least one KEY.
```shell
...
# OpenAI's key & baseUrl
OPENAI_KEY=#your key
OPENAI_PROXY_URL=#baseURL# Searxng hostname.
SEARXNG_HOSTNAME=http://searxng:8080
```3.**Edit** [model.json](https://github.com/yokingma/search_with_ai/blob/main/deploy/model.json) **file.** [Optional]
```json
{
"platform": "openai",
"type": "openai",
// add your models
"models": ["o1-preview", "o1-mini", "gpt-4o", "gpt-4o-mini"]
}
```4.**Run with Docker Compose.**
```shell
docker compose up -d
```Then visit
5.**Update**
- Delete old images using Docker Desktop or Docker CLI (if needed)
- Run ```docker compose down```
- Run ```docker compose up -d```## LLMs
#### Support
* OpenAI ChatGPT
* Google Gemini
* Lepton LLama2、Mixtral8*7B
* AliYun Qwen
* Baidu Wenxin
* 01.ai
* Moonshot(Kimi)
* DeepSeek
* ChatGLM
* Tencent Hunyuan
* Ollama, LMStudio#### Local LLM
Support [Ollama](https://github.com/ollama/ollama), [LMStudio](https://github.com/lmstudio-ai/lms)
## Search Engine
Built-in support for search engine: Bing, Google, SearXNG
#### SearXNG (Free, No Key required)
Install [SearXNG](https://github.com/searxng/searxng) with [searxng-docker](https://github.com/searxng/searxng-docker)
> SearXNG is a free internet metasearch engine which aggregates results from various search services and databases. The service does not track or profile its users, providing online anonymity for those who seek it. Additionally, SearXNG can be used over Tor for online anonymity.When you install SearxNG, the only active output format by default is the HTML format. You need to activate the json format to use the API. This can be done by adding the following line to the settings.yml file:
```yaml
search:
formats:
- html
- json
```And set limiter to false:
```yaml
server:
limiter: false # default is true
```You can also set the host in .env:
```shell
# SEARXNG_HOSTNAME=
```#### Bing Search
To use the Bing Web Search API, please visit [this link](https://www.microsoft.com/en-us/bing/apis/bing-web-search-api) to obtain your Bing subscription key.
> The Bing Search API is billed, but has a free tier of 1000 calls per month.#### Google Search
You have three options for Google Search: you can use the SearchApi Google Search API from [SearchApi](https://www.searchapi.io/), [Serper](https://www.serper.dev/) Google Search API from Serper, or opt for the [Programmable Search Engine](https://developers.google.com/custom-search) provided by Google.
#### ChatGLM Web Search
[2024/09/17] Added Zhipu AI's ChatGLM Web Search plugin, used as a Chinese search engine.
> Zhipu AI's glm-flash is currently free, and its Web Search plugin is also free. Based on these two, ChatGLM has been added as a free Chinese search engine.#### Jina Reader URL API
[2024/11/24] Added [Jina](https://jina.ai/) Reader URL API, supporting full web content extraction.
When selecting the [Research] mode on the web page, the Jina API will be called to extract the full content of the web page as context for the AI. You need to configure JINA_KEY:```shell
# JINA API KEY
JINA_KEY=#your key
```## Deploy & Development
> Node.js >= 20
> Turborepo
> PackageManager: [email protected]* **Directory Structure**
```text
apps/
| server # backend
| web # frontend
deploy/
| docker-compose.yaml # docker deployment file
| .env.docker # backend configuration file
| model.json # backend model configuration file
...
```* **Development & Build**
In the root of the project:```shell
turbo dev
# or
turbo build
```* **Update**
In the root of the project:```shell
git pull
```## License
This repository's source code is available under the [MIT License](LICENSE).
[🚀Back to top](#top)