1. 尝试新的开发组合:Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS
  2. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之配置IdentityServer
  3. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之数据迁移
  4. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之添加实体
  5. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之显示登录视图
  6. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之验证码
  7. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之登录、权限、菜单和登出
  8. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之文章管理
  9. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之文件上传
  10. Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之部署到Linux
  11. 在CentOS上使用VS Code调试.Net Core应用程序

在《Asp.NET Core+ABP框架+IdentityServer4+MySQL+Ext JS之部署到Linux 》一文中,部署的应用程序存在许多小问题,于是决定直接在Linux系统上使用VS Code来调试,看能不能解决这些问题。

在开始前,首先要做的是在虚拟机上装一个带有图形界面的CentOS。系统安装好以后,按照部署一文设置好Apache、MariaDB和.Net Core,然后开始安装VS Code,安装步骤可以参考文章《Running VS Code on Linux》。在这里主要参考的就是RHEL,Fedora and CentOS based distributions这一节。主要步骤就是先安装签名和存储,命令如下:

sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc
sudo sh -c 'echo -e "[code]\nname=Visual Studio Code\nbaseurl=https://packages.microsoft.com/yumrepos/vscode\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" > /etc/yum.repos.d/vscode.repo'

然后是安装VS Code:

yum check-update
sudo yum install code

安装完成后,在图像界面中打开终端窗口,输入code或在应用程序→编程或附件中就可能看到Visual Studio Code的选项了。VS Code运行后会看到如下图所示的效果。

VS Code安装好以后,根据文章,最好还要装Node.js,根据《Installing Node.js via package manager》一文,安装步骤是,先下载Node.js 9

curl --silent --location https://rpm.nodesource.com/setup_9.x | sudo bash -

然后安装:

sudo yum -y install nodejs

最好安装上生成工具:

sudo yum install gcc-c++ make

到目前为止,VS Code只是一个文本编辑工具而已,还不具备开发C#应用程序的一些所需功能,这个需要根据《Working with C#》一文来武装VS Code,其实就是安装一些扩展。在VS Code界面中,单击最左边的图标按钮中的最后一个图标来安装扩展。主要的扩展包括C#Code RunnerC# ExtensionsC# FixFormat

VS Code在第一次打开的时候会检查是否已经安装了Git,如果没有会提示安装Git。如果直接使用Yum安装,安装的是1.8版本的,不符合VS Code所需的版本要求2.1以上的要求,这个只能编译安装了,具体安装步骤可参考《How to Install Git 2.15 on CentOS/RHEL 7/6,Fedora 27/26/25 》这篇文章。

一切准备就绪,现在可将应用程序项目通过SFTP上传到服务器,然后用VS Code打开项目文件夹了。在项目打开后,VS Code会自动恢复项目的依赖项。等依赖项都恢复后,先要做的是修改两个项目的appsettings.json文件,把数据库连接修改好。修改完成后,按CTRL+`键打开终端窗口,在窗口中输入以下命令执行迁移项目:

dotnet run --project "/home/dq/SimpleCmsWithAbp/src/SimpleCmsWithAbp.Migrator/SimpleCmsWithAbp.Migrator.csproj"

在提示中输入y开始迁移数据库。

数据库迁移后,在文件列表中,在SimpleCmsWithAbp.Web.Host.csproj文件上单击鼠标右键选择Run Code运行项目,项目运行后,使用POSTMAN来发送一个获取验证码的请求,这时候会在输出中看到错误信息,又或者打开App_Data\Logs\Logs.txt文件,可以发现错误是Unable to load DLL 'gdiplus'。这个库在上一文安装过,但没有解决问题,再试试看看。这次不打算编译安装了,在《libgdiplus-2.10-9.el7.x86_64.rpm》找到了yum的安装方式,具体步骤是先添加EPEL repository,命令如下:

yum -y install epel-release

然后安装:

yum install libgdiplus

安装以后,还是出现错误,还是找不到DLL,然后通过以下命令将gdiplus.dll链接为libgdiplus.so:

ln -s /usr//lib64/libgdiplus.so gdiplus.dll

终于可以顺利获取到验证码了,问题解决。

现在在客户端可以顺利登录了。下面要解决的是上传文件的路径问题,在Application项目,将MediaAppService.cs中设置上传路径的代码修改为以下代码:

var dir = $"/var/www/mediae/{path}";

好了,再测试,这时候提示的权限问题了。这个好解决,将\var\www\mediae文件夹的用户和用户组设置为apache:apache,将权限设置为766就顺利通过了。

调试好以后,就可以将项目发布到\var\www\cms文件夹了,在终端运行以下命令就可以了:

dotnet publish --project "/home/dq/SimpleCmsWithAbp/src/SimpleCmsWithAbp.Migrator/SimpleCmsWithAbp.Web.Host.csproj" -o "/var/www/cms"

项目发布以后,修改appsettings.json里的设置,修改log4net.config文件,将日志文件输出修改为:

<file value="/var/log/httpd/cms-logs.txt" />

这里还要修改/var/log/httpd文件夹的用户和用户组,不然日志不能写入。

最后是终极大招,把SELinux禁用了,世界终于安宁了。

至此,SimpleCmsWithAbp终于可以顺利的在Linux上运行了。

在CentOS上使用VS Code调试.Net Core应用程序的更多相关文章

  1. VSCode配置react开发环境的步骤

    本篇文章主要介绍了VSCode配置react开发环境的步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. CentOS 8.2服务器上安装最新版Node.js的方法

    这篇文章主要介绍了CentOS 8.2服务器上安装最新版Node.js的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. React-vscode使用jsx语法的问题及解决方法

    很多朋友在安装插件ES7 React/Redux/GraphQL/React-Native snippets还是不能完全支持jsx语法,纠结是什么原因呢,该如何处理呢,下面小编给大家分享本文帮助大家解决React-vscode使用jsx语法问题,感兴趣的朋友一起看看吧

  4. 详解如何在vscode里面调试js和node.js的方法步骤

    这篇文章主要介绍了详解如何在vscode里面调试js和node.js的方法步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. centos+php+coreseek+sphinx+mysql之一coreseek安装篇

    这篇文章主要介绍了centos+php+coreseek+sphinx+mysql之一coreseek安装篇的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下

  6. 解决VSCode调试react-native android项目错误问题

    这篇文章主要介绍了VSCode调试react-native android项目错误解决办法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  7. Centos7 中 Node.js安装简单方法

    这篇文章主要介绍了Centos7 中 Node.js安装简单方法,非常不错具有一定的参考借鉴价值,需要的朋友可以参考下

  8. 解决vscode Better Comments插件在vue文件中不显示相对应的颜色的问题

    最近使用了Better Comments这款插件,发现在ts文件中可以显示对应的颜色,但在vue文件中并不显示对应颜色 ,下面小编给大家分享解决方法,感兴趣的朋友跟随小编一起看看吧

  9. VSCode使React Vue代码调试变得更爽

    这篇文章主要为大家介绍了VSCode使React Vue代码调试变得更爽的使用方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. 在VSCode中搭建Python开发环境并进行调试

    这篇文章介绍了在VSCode中搭建Python开发环境并进行调试的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

随机推荐

  1. 如何在.NET Core类库中使用System.Windows.Forms

    我的project.json文件:我所有的net40特定代码都在NET40下定义.有什么想法吗?

  2. 发布到IIS.省略在服务器上安装.NET Core Windows Server Hosting软件包

    ASP.NETCore文档说,其中一个先决条件是目标服务器上的install.NETCoreWindowsServerHostingbundle.是否有可能以某种方式将此依赖项包含在由dotnet-publish创建的自包含包中,并避免现场安装?不.该软件包包含Asp.Net核心模块–以及使用IIS运行Asp.NETCore应用程序所需的本机IIS模块.如果未安装Asp.NET核心模块并且您通过安

  3. 在CentOS上使用VS Code调试.Net Core应用程序

    VSCode运行后会看到如下图所示的效果。在VSCode界面中,单击最左边的图标按钮中的最后一个图标来安装扩展。主要的扩展包括C#、CodeRunner、C#Extensions和C#FixFormat。如果直接使用Yum安装,安装的是1.8版本的,不符合VSCode所需的版本要求2.1以上的要求,这个只能编译安装了,具体安装步骤可参考《HowtoInstallGit2.15onCentOS/RHEL7/6,Fedora27/26/25》这篇文章。一切准备就绪,现在可将应用程序项目通过SFTP上传到服务器

  4. CentOS下安装.net core环境并部署WebAPI

    如果提示如下内容就说明启动成功了。

  5. 部署.net core到CentOS系统

    locationNum=10&fps=1

  6. CentOS 7下发布.net core 2.0 过程

    第5步:在vs中发布工程到本地磁盘发布后的结果如下第6步:验证工程是否可以运行在CMD中切换到发布的目录,执行命令:dotnetASPCore2.dll如果出现如下图所示表明发布成功,可以测试一下localhost:50003.发布到CentOS,并启动服务第1步:用WinSCP拷贝至CentOS系统中的/var/www/qa/中第2步:在CentOS中测试是否可以运行:在Xshell中执行:/opt/core2.0.3/dotnet/var/www/qa/ASPCore2.dll结果没有问题,在Cent

  7. CentOS下使用.Net Core 1.1部署WebApi

    一、安装CentOS系统二、在CentOS上安装最新的.NetCore安装教程在官网已经很详细了。

  8. Ubuntu &amp; GitLab CI &amp; Docker &amp; ASP.NET Core 2.0 自动化发布和部署1

    经过上面四篇博文中的相关安装和配置,我们主要完成了两个容器的创建和运行:gitlab和gitlab-runner:本篇博文目的:使用GitLabCI脚本编译ASP.NETCore2.0程序,然后将编译后的文件传输到服务器上,最后使用SSH连接服务器,并运行程序,完成发布和部署。简单来说,就是我们每次使用gitpush提交完代码,自动完成发布和部署。

  9. 在CentOS上部署Asp.net Core应用程序

    在此之前,我将同样的程序已经成功发布到了Ubuntu,我觉得,既然已经有了前一次的成功经验,不论CentOS还是Ubuntu都是Linux,道理应该差不多吧。但事实证明,还是有些差异的,某些在CentOS上频出的问题在Ubuntu上却没有,所以我的感觉是Ubuntu部署Asp.netCore程序更容易些。Asp.netCore应用需要反向代理配合才能运行,IIS、Apache和Nginx等Web服务软件都可以作为它的反向代理。在Ubuntu下部署与这个差不多,某些命令不一样。

  10. dotnet core 在ubuntu 上运行 F#

    dotnetcore在ubuntu上运行F#线装dotnetcoreubuntusudoapt-getupdatesudoapt-getinstallmono-completefsharpsudoyumupdatesudoyuminstallmono-completefsharp

返回
顶部