您的位置:首页 > 运维架构 > Linux

.Net Core2.0秒杀CMS部署到Centos7.3遇到的坑,酸爽呀

2017-11-12 16:31 591 查看

一、Centos7.3的安装

打开VirtualBox,点击新建,如下图所示:





点击“下一步”,弹出下面的对话框,调整内存大小,建议设置为2G,这样操作更流畅点















设置好,点击“OK”,再点击“启动”,就进入到Centos的安装界面,



点击“软件选择”,弹出下面的界面,选择下面图中所标注的,测试环境没必要最小化安装,这样对于我这样的菜鸟来说,操作方便点。



点击“网络和主机名”,弹出下面的提示框,点击“开启”:

选择好之后,就等待安装,安装的到最后会让你设置root账号的密码,建议设置一下,右边的创建用户暂时先不设置,到此已经安装成功了,重启一下即可。这里我就一笔带过,因为网上都有安装的教程我就不啰嗦太多。



二、Nginx的安装

(1)环境调试确认

确认系统网络

确认yum可用

确认关闭IPtables规则

确认停用selinux

1)确认网络可用

  


  2)确认yum可用

  


  


  


  yum list|grep gcc #列出所有的gcc信息

  


  3)关闭IPTable

  如果你熟悉的话可以不用关,但对于我这样的菜鸟,我还是先关闭它。

  iptables -L

  iptables -F

  iptables -t nat -L

  iptables -t nat -F

  4)关闭SeLinux

  getenforce 查看SeLinux的状态,如果不为Disabled则,修改为该状态

  


  1、临时关闭(不用重启机器):

  setenforce 0 ##设置SELinux 成为permissive模式

2、修改配置文件需要重启机器:

  修改/etc/selinux/config 文件

  将SELINUX=enforcing改为SELINUX=disabled

  重启机器即可

  


  这里我已经修改为了disabled

  创建属于自己工作的目录,我的个人习惯:

  cd /opt

  mkdir app download logs work backup

(2)快速安装Nginx

新建一个nginx.repo文件,

把官网中对应的yum源复制到新建的nginx.repo文件中,并做一下修改:



注意:OS改为:centos OSRELEASE改为:7

修改完 :wq保存并退出。

使用:yum list | grep nginx 列出相关版本信息



使用:yum install nginx 安装

    安装完之后,执行下面的命令,可以查看对应的版本信息

  


关于Nginx更多的知识以后有机会再给大家介绍,目前只要成功安装Nginx就OK了。

systemctl start nginx #启动nginx

systemctl enable nginx #设置nginx的开机启动


然后在 CentOs系统 打开浏览器 输入 :192.168.0.109 (使用ifconfig查看IP)

看到下面 的页面说明安装成功,并启动成功了:



(3)安装.Net Core SDK(目前是2.0.2版本)

  可以参考微软的文档,非常详细:https://www.microsoft.com/net/learn/get-started/linuxcentos

(4)配置防火墙

  查看firewall服务状态

  systemctl status firewalld

  


查看firewall的状态

  firewall-cmd --state

  


开启、[b]重启、关闭、firewalld.service服务(如果关闭了请打开)[/b]

  # 开启

  service firewalld start

  # 重启

  service firewalld restart

  # 关闭

  service firewalld stop

# 查询端口是否开放
firewall-cmd --query-port=8080/tcp
# 开放80端口(如果想在外面可以访问到,要开启80端口)
firewall-cmd --permanent --add-port=80/tcp
# 移除端口
firewall-cmd --permanent --remove-port=8080/tcp

#重启防火墙(修改配置后要重启防火墙)
firewall-cmd --reload

# 参数解释
1、firwall-cmd:是Linux提供的操作firewall的一个工具;
2、--permanent:表示设置为持久;
3、--add-port:标识添加的端口;

三、项目发布并部署

把发布好的项目,上传到Centos的/opt/app/demo1/目录下面:



注意:上面的项目一定要在Startup.cs文件的Configure方法中添加下面的代码:(标红的部分)

app.UseForwardedHeaders(new ForwardedHeadersOptions
{
ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto
});

app.UseAuthentication();//注意添加这段代码就是想说明,如果有该段代码,则添加的代码一定要在该代码的前面添加,如果没有需求则可以去掉,上面的项目中是没有改段代码的


Nginx的配置

  修改下面目录中的default.conf文件:

  


  内容替换为:

  


配置守护服务(supervisor)

 yum install python-setuptools
 easy_install supervisor
 mkdir /etc/supervisor
 echo_supervisord_conf > /etc/supervisor/supervisord.conf


  修改:supervisord.conf

  


  修改内容为最后面的部分:

  


  其中files= conf.d/*.conf修改为:files = supervisord.d/*.ini

在再改目录下面创建一个目录,如下图所示:

  


  进入上面创建的目录里面,新建一个文件:MiaoSha.ini

  


  内容为:

  


  修改完之后,执行下面的命令:

  supervisord -c /etc/supervisor/supervisord.conf

  supervisorctl reload

  好了,现在可以在浏览器中输入:192.168.0.109:80,即可访问,但是我想开机的时候,就启动,需要做一下的配置:

配置Supervisor开机启动

  打开目录 /etc/systemd/system/ 新建文件 miaosha.service

  


  内容:

  


  然后执行:

  systemctl enable miaosha.service

  systemctl start miaosha.service

  systemctl status miaosha.service

  


  如果上图中出现同样的结果,说明已经配置成功,我们重启电脑,不用dotnet MiaoSha.Admin.dll了,即可在虚拟机中访问:192.168.0.109而且也可以在外面的浏览器中访问,下面展示这两种访问结果:

  在虚拟机中访问:

  


  本地访问:

  


四、总结

在部署的时候,也参考了 “ 农码一生” 的相关文章,但怎么也配置不成功,一直报502错误,后来参考了官网的配置,和自己摸索,终于部署成功,遇到很多坑,建议大家不要只看,动起手来,你就会知道其中的酸爽!好了,分享到这里吧,希望对你有帮助!

五、问题

后面会把写好的项目部署到阿里云上,如果遇到问题,会第一时间更新。

(1)首先感谢那些帮助我的人,很感谢!没有你们的帮助可能我会消耗更多的时间。

状态:已解决

时间:2017年11月14日晚

问题:站点可以访问,js css jpg加载不出来报404

解决办法:

1)首先我们看看发布的这个项目代码 Program.cs和Startup.cs文件的代码:

public class Program
{
public static void Main(string[] args)
{
BuildWebHost(args).Run();
}

public static IWebHost BuildWebHost(string[] args) =>
WebHost.CreateDefaultBuilder(args)
.UseKestrel()
.UseContentRoot(Directory.GetCurrentDirectory())
.UseIISIntegration()
.UseStartup<Startup>()
.UseUrls("http://localhost:5000")
.Build();
}


// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{

app.UseForwardedHeaders(new ForwardedHeadersOptions
{
ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto
});

app.UseStaticFiles();
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Login}/{action=Login}/{id?}");
});
}


    2)Nginx的配置

    


    3)访问结果:(图片、js、css、json文件404,即使你再路径前面加上wwwroot还是报404)



出现问题的原因是很多的,在保证你代码总的图片路径是正确的前提下,可能的原因是:反向代理的路径下找不到文件,需要单独指定js css文件的访问路径。

修改Nginx的配置如下(重启Nginx):



注意:root后面的路径,之前我的路径没有加上wwwroot/ 还是报404,加上之后再访问就没有问题了,可以在上面的()里面添加你的静态资源文件的后缀名,这样Nginx就可以直接转发请求的静态资源文件。

expires 1d 表示缓存的时间,如果这些静态资源基本上没有变化的话,可以把该值设置大点。



(2)

状态:已解决

时间:2017年11月15日晚

问题:在配置supervisor时,配置完成,启动时遇到:cannot unlink stable.sock什么之类是问题

解决办法:重新安装supervisor,具体可以参考:

配置守护服务(supervisor)配置节

(3)

状态:已解决

时间:2017年11月26日11:56:12

问题:Centos7.3手欠更新一下最新的.Net Core SDK 2.0.3,使用dotnet -version 发现:bash dotnet 未找到命令

原因:微软的pkg包居然没有添加环境变量, 也没有软连接dotnet

解决办法:更新了是不是还需要再安装一下,于是就重新安装了一遍,但是还报上面的错误。最后添加了一下软连接

step1:



step2:



step3:



注意:是把第二个:usr/share/dotnet/dotnet 挂到 /usr/local/bin/dotnet

作者:郭峥

出处:http://www.cnblogs.com/runningsmallguo/

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐