部署ror时候出现的两个问题
很多时候灵感来了,要做点什么或写些点什么,马上就能搞定。。
而当没有灵感的时候 ,为了干这点活,会极其郁闷的慢慢来进入状态,,然后慢慢的狗屎一些逻辑,,最后才能完成憋出点屁来。。闻起来还有点臭味。
话说。搞ror也有不少天了,今天再扯两个细节:
一个就是 no-route-matches-get-assets
网站发布后 在访问 图片或css等资源时候,出现这等问题处理方法:
config/environment/production.rb
config.serve_static_assets = false 改为 true
使用说明书说:通过配置Apache或nginx可以不用改。我暂时不想配。麻烦。。所以我就改成true了。
另外一个问题是:我调用了blueprint里面的css,这些css默认是不会被 预编译的,如果不能被预编译:bundle exec rake assets:precompile,,那个发布后是有问题的。所以这个问题是一定要解决的。
config/environments/production.rb
直接改成下面这样,完事。
config.assets.precompile += %w( *.css *.js )
,
网上有些哥问,为什么不设置成 默认编辑全部的css 呢?
开发的家伙回答:这个也是有争议的问题,目的是想把所有的css都集合到一个application.css里面,也就不想单独去编译每个css。。。
::出发点是好的,可以减少读取css文件的次数,,但这个浏览器混杂,ie横行,快速升级的年代,一个css文件的网站,能够在所有的浏览器下面显示的都正常吗,都合适吗?
==============
最后还有问题,困扰我好多年。。。。。
每次我 重新部署了 ror 后,没什么 ,我要重启电脑才生效,
而单纯要重新启动我的nginx服务器,没鸟用呢。。 哪里配置有问题呢?
upstream www.lehazi.com{
server 127.0.0.1:3000;
}
server {
listen 80;
server_name www.lehazi.com ;
access_log /var/log/nginx/localhost.access.log;
error_log /var/log/nginx/localhost.error.log;
root /var/www/www.lehazi.com/current/public;
index index.html index.htm;
location / {
proxy_pass http://www.lehazi.com;
}
location /doc {
root /usr/share;
autoindex on;
allow 127.0.0.1;
deny all;
}
error_page 404 /404.html;
}
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /var/www/nginx-default;
}
}