基于Ubuntu Ollama 部署 DeepSeek-R132B 聊天大模型(附带流式接口调用示例)

最近 DeepSeek出来了,很火,说是能跟ChatGpt o1 媲美,结果,用了DeepSeek的官方服务,提示"服务器繁忙 请稍后再试。",我就想,算了,自己部署个吧。

我这个是基于docker部署的,首先要docker 支持 显卡,这样才会跑的更快,基于CPU 还是比较卡的,耗费的内存也比较多。

部署非常方便,除了下载很慢,基本都是环境问题,环境解决完就没啥大问题。

服务器基础资源

这就来个服务器部署,目前服务器资源大致如下:

操作系统 : Ubuntu 24.04

显卡:Tesla P100-PCIE-16GB * 2

CPU:48核

内存:64G

运行docker命令

复制代码
docker run --name ollama -d --restart=always --gpus=all -v /data/docker/ollama:/root/.ollama -p 11434:11434 ollama/ollama

运行完即可

然后,进入到容器内开始执行命令

复制代码
docker exec -it ollama /bin/sh

然后执行 下载并运行32B 的模型

复制代码
ollama run deepseek-r1:32b

如果资源不够,可以运行 1.5b 或者 7B的模型

复制代码
ollama run deepseek-r1:1.5b

下载提示

如果像上面这样能得到MB以上的速度,就说明网络已经非常好了,实际上过一会儿就会降到几百KB,很慢,这个时候,我们只需要 Ctrl + C ,然后,重新输入下载的命令速度就会提升上来,重复此过程,可以加快下载。

运行模型

先给几个命令

csharp 复制代码
ollama pull deepseek-r1:1.5b //拉取模型
ollama run deepseek-r1:1.5b //运行模型
ollama list  //查看所有模型

允许防火墙,这样就可以在自己局域网电脑上访问了

复制代码
sudo ufw allow  11434/tcp

来先看下都有什么模型

复制代码
ollama list

有三个模型了

好了,我们先运行模型

复制代码
ollama run deepseek-r1:32b

直接提示要发送一个消息给它,我们给它一个消息,比如,DeepSeek为何如此优秀?

好吧,回答的好简短,好官方,然后,再问他,如何看待目前的各种AI产品?

这次就回答的特别多了。

现在模型部署好了,我们也可以通过 http地址来看当前 Ollama运行的状态如何.

复制代码
http://192.168.0.120:11434/

也可以通过 这个api查看部署的模型有什么

复制代码
http://192.168.0.120:11434/api/tags

可以看到,我用Ollama部署了3个模型。

gpu资源耗费情况

可以看到还好,单卡16GB,还剩5GB 左右,留给其他业务使用。

接口的方式来调用DeepSeekR1,控制台流式输出

实际上Ollama部署好模型后,就可以直接用接口来调用了。

这个就是我自己调用接口实现的本地效果,也是很好用的,省的在docker里面敲来敲去。

主要用.net代码

引入一个nuget包

csharp 复制代码
Codeblaze.SemanticKernel.Connectors.Ollama

具体代码如下:

csharp 复制代码
static async Task Main(string[] args)
{
    var builder = Kernel.CreateBuilder().AddOllamaChatCompletion("deepseek-r1:32b", "http://192.168.0.120:11434");

    builder.Services.AddScoped<HttpClient>();
    var kernel = builder.Build();

    while (true)
    {
        string input = "";
        Console.Write("请输入: ");
        input = Console.ReadLine();
        Console.WriteLine("");
        var contents = kernel.InvokePromptStreamingAsync(input);

        if (contents == null)
        {
            Console.WriteLine("Error: 内容为空!");
            continue;
        }
        else
        {
            Console.WriteLine($"\nDeepseek: \n");
            await foreach (var item in contents)
            {
                Console.Write(item.ToString());
            }
        }
        Console.WriteLine("");
    }
}

相关地址

复制代码
https://github.com/kesshei/OllamaDemo
https://gitee.com/kesshei/OllamaDemo

总结

DeepSeek来的刚好,也希望这辈子有幸看到不一样的世界。

相关推荐
bingHHB3 分钟前
电商售后服务系统与其他系统集成:实现售后流程自动化
大数据·运维·数据库·自动化·接口隔离原则·集成学习
huangyuchi.25 分钟前
【Linux】权限相关指令
linux·运维·服务器·笔记·指令·权限
☆凡尘清心☆26 分钟前
CentOS 7 环境下部署 LAMP
linux·运维·centos
TDengine (老段)31 分钟前
TDengine 运维——巡检工具(安装前检查)
大数据·运维·数据库·物联网·时序数据库·tdengine·涛思数据
摘星编程37 分钟前
华为云Flexus+DeepSeek征文 | 基于Dify和DeepSeek-R1开发企业级AI Agent全流程指南
人工智能·华为云·deepseek·华为云flexus·dify-llm
FBI HackerHarry浩2 小时前
云计算Linux Rocky day02(安装Linux系统、设备表示方式、Linux基本操作)
linux·运维·服务器·rocky
惊起白鸽4503 小时前
LVS+Keepalived高可用群集
linux·服务器·lvs
潘yi.3 小时前
LVS+Keepalived高可用群集
linux·服务器·lvs·keepalived
洁✘3 小时前
LVS-DR群集
linux·服务器·lvs
jz_ddk3 小时前
[学习] C语言多维指针探讨(代码示例)
linux·c语言·开发语言·学习·算法