云服务器搭建Python项目实现学术优化chatgpt

news2024/11/24 1:04:08

云服务器搭建实现学术优化chatgpt

  • 1 服务器准备
  • 2 云服务器配置
    • 2.1 python虚拟环境
      • 2.1.1 python3.9安装配置
      • 2.1.2 下载python项目
      • 2.1.3 创建python虚拟环境
  • 3 后台运行python项目(不然不能关闭与云服务器的连接,那意义何在?)

1 服务器准备

一个可以访问openAI的服务器,内地配置具体见我上篇文章:

云函数搭建内地可用的OpenAI代理

这里用的是腾讯云服务器,OpenCloud centos 8系统

2 云服务器配置

上一篇文章写了如何配置FTP用于与linux云服务器的文件传输

云函数搭建内地可用的OpenAI代理中的第二章节

2.1 python虚拟环境

云服务器好像是自带python3.6.8的,由于项目所需环境比较新,所以要重新安装,越新越好,不然会有很多莫名其妙的问题,或者首先你就会被虚拟环境宰了。比如:
在这里插入图片描述
卸载 Python 3.6.8:

sudo yum remove python=3.6.8

或卸载 Python(建议这个,全卸了,避免某些还给你保留了python2):

sudo yum remove python

2.1.1 python3.9安装配置

  1. 安装 Python 3.9:
sudo yum -y install python=3.9
  1. 检查 Python 3.9 是否成功安装:
python --version
  1. 若安装不成功,可以尝试先安装 EPEL 仓库,再重复进行1和2
sudo yum -y install epel-release

如果你不是centos,可能自带的第三方软件包就不是yum,可以换成apt-get试试

2.1.2 下载python项目

  1. 找一个文件夹放项目,确认自己找得到这个路径。
 git clone https://github.com/binary-husky/chatgpt_academic.git

如果你没有安装git,还是要安装git,但是我觉得安装git太麻烦了,再加上从github上下载可能速度较慢,我直接自己本地下载完利用ftp传输上来的。

而且本地下载的话修改比较方便,我想你也不想用那个可恶的vim吧?

  1. 复制config.py到一个config_private.py文件,修改里面的API_URL指为上篇文章弄到的那个香港代理地址加上后面这段/v1/chat/completions

因为香港代理地址仅仅表示的是https://api.openai.com

  1. 因为是直接映射的,所以就不需要代理了,USE_PROXY = False

  2. API_KEY填自己的key

  3. 另外在main.py文件里的最后一段话里面记得加个参数share=True,否则不生成外部链接(不仅在局域网中可以访问)啊。

demo.queue(concurrency_count=CONCURRENT_COUNT).launch(server_name="0.0.0.0", share=True, server_port=PORT, auth=AUTHENTICATION, favicon_path="docs/logo.png")

在这里插入图片描述
在这里插入图片描述

2.1.3 创建python虚拟环境

如果你的linux是带图形界面的,可以考虑用pycharm,在里面装python环境比较友好一些,摆脱命令行。

要在Python中创建一个虚拟环境,

找个文件夹放虚拟环境,我是就放在项目目录下的,

可以按照以下步骤进行操作:

  1. 安装virtualenv模块:

    pip install virtualenv
    
  2. 在命令行中,导航到要创建虚拟环境的目录,创建虚拟环境:

    virtualenv env_name
    

    其中,env_name是您要为虚拟环境指定的名称。请注意,这将会在当前目录中创建一个名为env的新文件夹,并将虚拟环境安装到其中。

  3. 激活虚拟环境。要在命令行中激活虚拟环境,请执行以下命令:

    source env_name/bin/activate
    

    在Windows系统上,要激活虚拟环境,请运行以下命令:

    env_name\Scripts\activate
    
  4. 现在就处于虚拟环境中,可以自行安装相应的安装包了。本项目中,

    python -m pip install -r requirements.txt
    

要注意,此时所在目录一定要是项目的目录,不然找不到这个requirements.txt文件,你可以pwd看看当前目录路径,也可以ls看看当前路径下有哪些文件。

  1. 有了环境,有了项目就可以直接运行了,

    python main.py
    

如果你2.1.2节中的修改没有问题,这时已经好了,并且会生成两个链接。输出大概是这样:

在这里插入图片描述

这时候就已经好了。确实可以通过public URL 来打开,
but,有个很尴尬的问题,当你退出远控登录后,程序就退出了,那么如何永驻?

3 后台运行python项目(不然不能关闭与云服务器的连接,那意义何在?)

如果不能脱离本地主机而持续存在,那上云的意义何在?

第一反应就是将程序“服务化”

想了下关键词,是后台运行。

在先前的项目目录中在先前的虚拟环境中

nohup python -u main.py > logfile.log 2>&1 &

解释:

  • nohup 不是指定的在后台运行,但是这个nohup是让程序永久运行下去,和前后台没关系(这个不用改)

  • “-u”表示不启用缓存,实时输出打印信息到日志文件(如果不加-u,则会导致日志文件不会实时刷新代码中的print函数的信息)
    但程序还是运行滴,但总体还是不舒服的,不在掌控中。就是你感觉程序好像崩了。

  • main.py 这个是项目的主程序,就是想要运行的程序

  • “> logfile.log” 这个右括号是把你的输出的日志到后边的logfile.log日志文件中

  • 2>&1 这个2表示的当出错的时候输出的错误信息 >& 这个表示重定向;1表示标准输出 ,所以结合起来就是把错误信息重定向到标准输出

  • & 这个表示在后台运行

如果没搞好,nohup命令也会给你个进程号,如果你发现有地方不对,记得杀进程再重新搞(毕竟nohup这命令是要永久后台运行!)

kill -9 PID

-9应该是一种属性比如不顾一切地杀了(千万别觉得这是进程号,我当初就是这么把自己玩崩了);PID是指进程号,就是上述命令返回的那个值。

如果你后台运行完觉得万事大吉了,然后关了,然后发现不对劲,但是找不到进程了,怎么找进程?

ps aux |grep main

That’s all.

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

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

相关文章

GEE:将年度NDVI时间序列影像集合(Image Collection)转变为多波段影像,并下载

作者:CSDN @ _养乐多_ 本文将重点介绍如何使用 Google Earth Engine (GEE) 将多波段影像堆叠并导出,并探讨其应用场景和好处。 通过使用 GEE 的多波段影像堆叠功能,我们可以将不同波段的遥感影像整合成一个多波段影像,以支持各种地理空间分析任务。这种方法适用于遥感影…

以太网端口类型

以太网端口有 3种链路类型:access、trunk、hybird Access类型端口只能属于1个VLAN 般用于连接计算机 端口;Trunk类型端口可以允许多个VLAN通过,可以接收和发送多个VLAN 报文,一般用于交换机之间的连接;Hybrid类型端口可以允许多个VLAN通过,可…

Dubbo的使用

Dubbo在开发中,存在两种开发思路。基于SOA(面向服务的体系架构)思想和辅助SpringCloud架构提升效率。 Dubbo 默认使用 Netty 框架 Dubbo基于SOA思想 正常SpringBoot项目是只有一个启动类,接口定义在web层(即Controller层)中,然后调用Service层。&…

Matlab 梯度下降法

一、简介 梯度下降法(Gradient descent)或最速下降法(steepest descent)是求解无约束最优化问题的一种常用方法。 假设fx)在R上具有一阶连续偏导数的函数。要求解的无约束最优化问题是。其本质是一个迭代的方法,选择…

VMware Workstation 网络备忘 + 集群规模

概述 在虚拟机中部署服务,进行IP规划,进行相关的前期准备 3 张网卡 2个不同的网段 1个NAT 概述截图 NAT 截图 VMnet0 截图 VMnet1 截图 总结: 网卡(网络适配器)名称IP网段备注NATens33192.168.139.0VMnet0ens34VMne…

手把手教你在RT-THREAD bsp上运行pikascript脚本点亮小灯

简介 这篇文章介绍如何在RT-THREAD bsp上运行pikascript脚本。 pikascript相当于一个小型的micropython。 最近有一些结构上的调整,写这篇文章大概介绍一下如何使用,以及开发过程中需要注意的问题。 这篇文章几乎适配所有的RT-THREAD上的bsp。&#xff…

在Kubernetes(K8S) 上运行第一个应用

1、启动代理 : kubectl proxy 2、部署应用程序最简单的方式是使用 kubectl run 命令,该命令可以创建所有必要的组件而无需JSON或YAML文件。 --imageluksa/kubia 显示的是指定要运行的容器镜像,--port8080 选项告诉Kubernetes应用正在监听808…

每日一算-冒泡排序

冒泡排序是最简单的排序算法,如果相邻元素的顺序错误,则通过重复交换它们来工作。该算法不适用于大数据集,因为它的平均和最坏情况时间复杂度都很高。 原理 输入: arr[] {6, 3, 0, 5} 第一步: 冒泡排序从最前面的两个…

每日一算-选择排序算法

大家好,我是易安! 今天我们开始每日一算的篇章,今天带来的是选择算法。 选择排序是一种简单而高效的排序算法,它通过从列表的未排序部分中重复选择最小(或最大)元素并将其移动到列表的已排序部分来工作。该…

Kubernetes集群安全加固

本博客地址:https://security.blog.csdn.net/article/details/130678814 一、系统账户加固 1、对账户的登录次数进行检查,连续超过3次登录失败后,对用户锁定150s # 每个设备上都运行 sed -i~ 2iauth required pam_faillock.so deny3 unloc…

玩转Google开源C++单元测试框架Google Test系列(gtest)之五 - 死亡测试

一、前言 “死亡测试”名字比较恐怖,这里的“死亡”指的的是程序的崩溃。通常在测试过程中,我们需要考虑各种各样的输入,有的输入可能直接导致程序崩溃,这时我们就需要检查程序是否按照预期的方式挂掉,这也就是所谓的…

CBFS Shell .NET 22.0.85 Crack

使用虚拟文件夹、自定义菜单、工具栏、详细信息列等扩展和自定义 Windows 资源管理器! CBFS Shell 窗口资源管理器自定义 使用 CBFS Shell 为您的用户扩展 Windows 资源管理器。定义用户如何与文件和文件夹交互、自定义上下文菜单、添加信息列等。与可能导致资源管…

详细解释什么是LNMP架构

LNMP(Linux-Nginx-MySQL-PHP)是一种常见的Web服务器架构,适用于中小型网站和应用。 它包括四个核心组件: 1. Linux:LNMP架构是在Linux操作系统上运行的。通常选择Ubuntu、Debian等基于Debian的发行版作为Linux系统。 2. Nginx:Nginx是一个高性能的Web服…

支付系统设计三:支付网关设计09-总结

文章目录 前言一、设计目标二、设计实现1. 开发框架2. 配置管理后台3. 屏蔽渠道差异4. 各阶段工作内容4.1 业务处理前期准备阶段4.2 业务处理阶段4.2.1 交易处理模板获取4.2.2 参数验证4.2.3 幂等性验证4.2.4 交易数据准备服务获取4.2.5 路由处理4.2.6 支付渠道数据补全4.2.7 交…

Docker高级(完结)

一、DockerFile DockerFile简介 Docker是用来构建Docker镜像文件,由一条条docker指令和参数构成的脚本。 DockerFile构建过程 小总结 从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段, Dockerfile是…

浅析垃圾回收

大家好,我是易安! Java虚拟机的自动内存管理,将原本需要由开发人员手动回收的内存,交给垃圾回收器来自动回收。不过既然是自动机制,肯定没法做到像手动回收那般精准高效 ,而且还会带来不少与垃圾回收实现相…

《MongoDB入门教程》 - MongoDB基础介绍

前言 时间也过太快了嘛,一晃上次更新都又过去6个月了,再不更新就变成年更博客了。 对了,第一次疫情也过去了,最近开始二阳了,希望大家能继续挺过去吧 本篇文章初尝试使用ChatGPT进行,博主主要负责排版和总…

mysql使用xtrabackup方式复制过滤某一个数据库

需求: 搭建一个新的从库,只复制过滤源端数据库里的其中一个数据库workflow到新实例上。 一 操作步骤 1.1 在目标端新建一个数据库实例 略 1.2 在源端做备份 /home/urman-agent/bin/xtrabackup --defaults-file/data/mysql/etc/13314/my.cnf --targ…

redis缓存穿透、缓存击穿、缓存雪崩

一、缓存 缓存是数据交换的缓冲区,是存储数据的临时地方,一般读写性能较高。 如浏览器会把静态资源先加载到浏览器缓存中,tomcat中有应用层缓存等,则数据库也有数据库缓存。 缓存的作用: 降低后端负载提高读写效率…

ES8基本命令

ElasticSearch是面向文档型数据库 构造类似于数据库:indexes(索引库数据库)-->types(类型表)-->documents(文档行)-->field(字段字段) 但是在7.X开始,Type已经开始被废弃。 正排索引:根据主键id关联内容,然后再找关键字…