前段时间我发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程。

有很多朋友一直提出希望能够支持 MySQL 数据库,考虑到已经有朋友在用 SQL Server,我在升级的过程中不能丢下对 SQL Server 的支持,必须让系统同时支持 SQL Server 和 MySQL。

为了简化安装部署过程,我开发了一个配套的配置工具。

使用自动化配置工具,可以在“数据库引擎”这一项中,切换 SQL Server 和 MySQL,而不需要部署不同的两套程序。

在本文我将介绍:

  • CentOS 安装配置 MySQL 数据库,创建数据库,执行脚本创建表结构。
  • 安装 Nginx,反向代理到客服系统服务端,并设置开机自启动
  • 安装 .net core ,部署客服系统并开机自启动

我详细列出了需要执行的命令的全过程,跟随本文可以在 30 分钟内完成部署。

简介

升讯威在线客服与营销系统是基于 .net core / WPF 开发的一款在线客服软件,宗旨是: 开放、开源、共享。努力打造 .net 社区的一款优秀开源产品。

完整私有化包下载地址

https://kf.shengxunwei.com/freesite.zip

当前版本信息

发布日期:2021-7-8

数据库版本:20210608a

通信协议版本:20210609

服务器版本:1.3.3.0

客服程序版本:1.3.3.0

资源站点版本:1.2.56.0

准备操作系统

  • 本文以 CentOS 8.3 为例进行说明,其它版本的 Linux 安装配置过程大同小异。

开放防火墙端口

客服系统默认使用 9527 端口进行通信,如果开启了防火墙,请在防火墙中开放此端口。

也可以更改为其它可用端口号,在后续配置客服系统服务端程序时要做对应的修改。

请确保您所使用的主机服务商提供的防火墙服务中,也开放了对应端口。如阿里云服务器需要在安全组规则中配置。

安装 MySQL 数据库引擎

  1. 下载

    wget https://dev.mysql.com/get/mysql80-community-release-el8-1.noarch.rpm

  2. 安装

    sudo yum install mysql80-community-release-el8-1.noarch.rpm -y

    sudo yum install mysql-community-server -y

如果报 Error: Unable to find a match: mysql-community-server

则先执行 yum module disable mysql

然后再执行 sudo yum install mysql-community-server -y

  1. 启动

    sudo systemctl start mysqld

  2. 查看安装时生成的临时密码

    sudo cat /var/log/mysqld.log |grep password

  3. 使用临时密码连接 MySQL

    mysql -uroot -p

  4. 修改 root 密码

    alter user root@localhost identified with mysql_native_password by '你的密码';

安装 Nginx

安装依赖项

  1. 安装 gcc

    yum -y install gcc

  2. 安装 pcre、pcre-devel

    yum install -y pcre pcre-devel

  3. 安装 zlib

    yum install -y zlib zlib-devel

  4. 安装 openssl

    yum install -y openssl openssl-devel

安装 nginx

  1. 下载

    wget http://nginx.org/download/nginx-1.20.1.tar.gz

如果提示 command not found,则先执行 yum install wget 安装

  1. 解压缩

    tar zxvf nginx-1.20.1.tar.gz

  2. 进入目录

    cd nginx-1.20.1

  3. 安装和配置,依次执行

    ./configure

    make

    make install

如果提示 command not found,则先执行 yum -y install gcc automake autoconf libtool make 安装

  1. 启动 nginx 服务

    cd /usr/local/nginx/sbin

    ./nginx

  2. 查看nginx服务是否启动成功

    ps -ef | grep nginx

  3. 访问你的服务器IP

    看到显示欢迎页面。

设置开机自动启动

  1. 进入到 /lib/systemd/system/ 目录

    cd /lib/systemd/system/

  2. 创建 nginx.service 文件

    vim nginx.service

如果提示 command not found,则先执行 yum -y install vim 安装

  1. 输入以下内容后保存退出

    注意其中的 nginx 安装路径
[Unit]
Description=nginx service
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s stop
PrivateTmp=true
[Install]
WantedBy=multi-user.target

内容说明

Description:描述服务

After:描述服务类别

[Service]服务运行参数的设置

Type=forking是后台运行的形式

ExecStart为服务的具体运行命令

ExecReload为重启命令

ExecStop为停止命令

PrivateTmp=True表示给服务分配独立的临时空间

注意:[Service]的启动、重启、停止命令全部要求使用绝对路径

[Install]运行级别下服务安装的相关设置,可设置为多用户,即系统运行级别为3

  1. 启动 nginx

    systemctl start nginx.service

  2. 加入开机自启动

    systemctl enable nginx.service

  3. 查看服务当前状态

    systemctl status nginx.service

安装 .Net Core

  1. 安装

    sudo dnf install dotnet-sdk-3.1

创建数据库

  1. 连接数据库引擎

    mysql -uroot -p

  2. 创建数据库

    create database kf

  3. 切换到数据库

    use kf

  4. 创建数据库表结构

    source createDatabase.sql

配置服务器主程序

请确认已经完成了对服务器主程序配置文件的配置。

参阅:使用自动化工具配置服务器端程序

配置主程序站点

  1. 上传并解压缩 Server 目录

    tar -xvf Server.tar

  2. 编辑 nginx 配置文件

    vim /usr/local/nginx/conf/nginx.conf

  3. 在 Server 节点 平级 添加如下内容

    注意 server_name 处替换为你所使用的域名。

map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
upstream dotnet_server_proxy {
server localhost:5000;
keepalive 2000;
}
server{
listen 80;
listen [::]:80; server_name kf-api.yourname.com; location / {
proxy_pass http://dotnet_server_proxy;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection keep-alive;
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}

示例文件:https://kf.shengxunwei.com/freesite/nginx.conf.txt

  1. 重新加载 nginx 配置文件

    cd /usr/local/nginx/sbin

    ./nginx -s reload

  2. 测试运行

    cd /root/wwwroot/Server/

    dotnet Sheng.Linkup.Server.dll &

  3. 访问域名,进入 Status 查看状态

    https://kf-api.yourname.com/Status

  1. 初始化数据

    访问域名,进入 Status/Setup 命令

    如:https://kf-api.yourname.com/Status/Setup

设置开机自启动

  1. 进入

    cd /lib/systemd/system/

  2. 创建文件

    vim kfServer.service

  3. 输入以下内容后保存退出

    注意 WorkingDirectory 为您的 Server 目录

[Unit]
Description=kfServer service
After=network.target
[Service]
Type=simple
GuessMainPID=true
WorkingDirectory=/root/wwwroot/Server/
StandardOutput=journal
StandardError=journal
ExecStart=dotnet Sheng.Linkup.Server.dll &
Restart=always
[Install]
WantedBy=multi-user.target
  1. 启动服务器主程序

    systemctl start kfServer.service

  2. 设置开机启动

    systemctl enable kfServer.service

  3. 查看运行状态

    systemctl status kfServer.service

配置静态资源站点

请确认已经完成了对服务器主程序配置文件的配置。

参阅:使用自动化工具配置服务器端程序

配置静态资源站点

  1. 上传并解压缩 Resource 目录

    tar -xvf Resource.tar

  2. 编辑 nginx 配置文件

    vim /usr/local/nginx/conf/nginx.conf

  3. 在 Server 节点平级添加如下内容

    注意 server_name 处替换为你所使用的域名。

    location 下的 root 后为 Resource 目录路径。

server {
listen 80;
server_name kf-resource.yourname.com; location / {
root /root/wwwroot/Resource;
index v.html;
} error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
  1. 为目录赋予访问权限
chmod 777 /root
chmod 777 /root/wwwroot
chmod 777 /root/wwwroot/Resource

配置发布客服端程序

此页面显示的是私有化部署版本的客服端配置说明,如果您在线使用,下载客服端程序请至:下载安装客服端软件

客服端程序运行需求

操作系统:

  • Windows 7 SP1 或更高版本
  • Windows Server 2008 R2 SP1 或更高版本

依赖:

  • 本程序需要 .Net Framework 4.8 或更高版本。

    私有化部署免费版压缩包中已经提供了“ndp48-web.exe”,这是 .Net Framework 4.8 的在线安装程序,推荐使用。只有 1 MB 多的大小,能够自动判断电脑是否已经安装了 .Net Framework 4.8 。

声明

客服程序没有任何恶意代码并经过病毒扫描。 使用的是:

  • ESET Internet Security
  • McAfee Total Protection

如果执行安装程序时显示 Windows SmartScreen 筛选器窗口,请点击“更多信息”后,点击“运行”按钮即可。

出现该窗口的原因 并不是发现恶意代码 ,而是单纯的指程序没有企业签名。

代码签名证书的价格较贵,需要每年近万元的费用,对于免费软件来说 成本高昂

此外 360 如果出现类似提示也是由于类似原因,并不是发现恶意代码,而是需要向 360 缴纳认证费。

启动客服端程序

压缩包中的“Shell”目录为客服端程序。

  1. 找到 Shell 目录下的“Sheng.Linkup.Client.Shell.exe”。

  1. 初次启动时,配置服务地址。

  1. 配置完成后,显示登录界面。

  • 如果提示没有返回版本信息,是因为在配置服务器主程序后,没有初始化数据。请查阅 配置服务器主程序 的结尾部分。
  • 如果登录时提示“不允许对非连接的套接字执行此操作”,请检查服务器的防火配置,将客服系统使用的通信规则添加到入站规则,参阅:准备操作系统
  1. 填写默认密码“123”,点击“登录”进入系统。

访客聊天测试

登录客服端以后,用浏览器打开你的资源站点域名下的聊天页面,如:

kf-resource.shengxunwei.com/WebChat/WebChat.html?sitecode=freesite

开始聊天。

发布

将配置好的客服端程序 Shell 目录,压缩或打包分发给客服使用即可。

集成

记一次 .NET 在线客服系统同时支持 SQL Server 和 MySQL 没卡死分析的更多相关文章

  1. Linux + .net core 开发升讯威在线客服系统:同时支持 SQL Server 和 MySQL 的实现方法

    前段时间我发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程. 有很多朋友一直提出希望能够支持 MySQL 数据库,考虑到已经有朋友在用 SQL Server,我在升级的过程中 ...

  2. Linux 运行升讯威在线客服系统:同时支持 SQL Server 和 MySQL 的实现方法

    前段时间我发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程. 有很多朋友一直提出希望能够支持 MySQL 数据库,考虑到已经有朋友在用 SQL Server,我在升级的过程中 ...

  3. 使用 WPF+ ASP.NET MVC 开发 在线客服系统 (一)

    近段时间利用业余时间开发了一套在线客服系统,期间遇到过大大小小不少问题,好在都一一解决,最终效果也还可以,打算写一个系列的文章把开发过程详细的记录下来. 希望能够和更多的开发人员互相交流学习,也希望有 ...

  4. Vue在线客服系统【开源项目】

    1. 项目介绍 一个基于Vue2.0的在线客服系统. 技术栈包含:Vue.VueX.Vue Router.Element UI. 2. 功能介绍 项目包含了2个模块:客服端和访客端. 2.1 客服端功 ...

  5. .net core 和 WPF 开发升讯威在线客服系统【私有化部署免费版】发布

    希望 .net 和 WPF 技术时至今日,还能有一些存在感. 这个项目源于2015年前后,当时开发的初版,我使用了 ASP.NET MVC 做为后端,数据库使用原生 ADO.NET 进行操作.WPF ...

  6. CentOS 30分钟部署 .net core 在线客服系统

    前段时间我发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程.期间有一些朋友希望能够给出 Linux 环境的安装部署指导,本文基于 CentOS 8.3 来安装部署.在本文中我 ...

  7. Docker 版 3分钟部署 .net core 开源在线客服系统,他来了

    我在博客园发表了一系列文章,开始介绍基于 .net core 的在线客服系统开发过程. 前些天又应朋友的要求,发了一篇 CentOS 版本的安装部署教程:https://www.cnblogs.com ...

  8. Linux + .net core 开发升讯威在线客服系统:首个经过实际验证的高性能版本

    业余时间用 .net core 写了一个在线客服系统.并在博客园写了一个系列的文章,写介绍这个开发过程: .net core 和 WPF 开发升讯威在线客服系统:目录 https://blog.she ...

  9. 使用 WPF + Chrome 内核实现 在线客服系统 的复合客服端程序

    本系列文章详细介绍使用 .net core 和 WPF 开发 升讯威在线客服与营销系统 的过程.本产品已经成熟稳定并投入商用. 免费使用 & 私有化部署免费下载:https://docs.sh ...

  10. .net core 和 WPF 开发升讯威在线客服系统:把 .Net Framework 打包进安装程序

    本系列文章详细介绍使用 .net core 和 WPF 开发 升讯威在线客服与营销系统 的过程. 系列文章目录: https://blog.shengxunwei.com/Home/Post/44a3 ...

随机推荐

  1. day104:MoFang:个人中心页面&flask-admin&基于faker生成仿真数据

    目录 BUG:登陆跳转并解决页面卡顿现象 1.前端显示个人中心页面 2.flask-Admin构建和配置后台运营站点管理用户信息 3.基于Faker生成仿真测试数据 BUG:登陆跳转并解决页面卡顿现象 ...

  2. 在smt贴片加工中手工焊接和机器焊接的区别

    在smt贴片加工领域,都需要将电子元件贴装在pcb板表面并进行焊接的,常用的焊接方式分为两种:手动焊接和全自动机器焊接,而常用的焊接机器有回流焊机和波峰焊机,那你知道他们的区别是什么吗?安徽英特丽带你 ...

  3. JS 对输入框进行限制(常用的都有)

    文章来源 http://www.soso.io/article/24096.html 1.文本框只能输入数字代码(小数点也不能输入) 代码如下: <input οnkeyup="thi ...

  4. Yum安装svn及配置

    svn配置 1.安装svn服务器端 yum install subversion 从镜像下载安装svn服务器端 cd /usr/local/ //进入目录,准备创建svn目录 mkdir svn // ...

  5. CS144 计算机网络 Lab1:Stream Reassembler

    前言 上一篇博客中我们完成了 Lab0,使用双端队列实现了一个字节流类 ByteStream,可以向字节流中写入数据并按写入顺序读出数据.由于网络环境的变化,发送端滑动窗口内的数据包到达接收端时可能失 ...

  6. 牛客网:华为机试题(python版本)

    输入一行:input() 输入的一行有多个信息:input().split() 有多组测试用例(多组同时输入): while true try except... 1.计算字符串最后一个单词的长度,单 ...

  7. java中各引用类型的生存时间

    引用类型由上往下一次减弱: 强引用:Object obj=new Object(),无论什么情况下,只要强引用关系还存在,就不会回收被引用的对象. 软引用:像系统中缓存这些,在系统即将报内存溢出异常时 ...

  8. 【python爬虫】对站长网址中免费简历模板进行爬取

    本篇仅在于交流学习 解析页面 可以采用xpath进行页面连接提取 进入页面 通过进入的页面可以得到下载地址 步骤: 提取表页面模板链接-->进入连接-->提取页面内下载地址连接--> ...

  9. JavaFx 关键字高亮文本实现

    原文地址:JavaFx 关键字高亮文本实现 - Stars-One的杂货小窝 整蓝奏云批量下载器里的搜索功能想到的一个关键字高亮功能,借助textflow组件来实现,记录一下 本文基于TornadoF ...

  10. 2022-04-24:用go语言重写ffmpeg的muxing.c示例。

    2022-04-24:用go语言重写ffmpeg的muxing.c示例. 答案2022-04-24: 本程序的大体过程如下: 打开输出文件并写入头部信息. 添加音频和视频流,并为每个流创建 AVCod ...