docker桌面环境ubuntu
拉取镜像:
docker pull dorowu/ubuntu-desktop-lxde-vnc
运行容器:
docker run -p 8001:80 -p 8002:5900 -e VNC_PASSWORD=VNC登录的密码 RESOLUTION=1920x1080 -v /dev/shm:/dev/shm dorowu/ubuntu-desktop-lxde-vnc
该镜像以VNC的方式连接到桌面环境服务器
注意,这里的容器暴露了两个端口
6080:是web版的vnc,可以在浏览器上直接访问桌面环境
显示分辨率可以通过环境变量来控制 如下:
docker run -p 6080:80 -e RESOLUTION=1920x1080 -v /dev/shm:/dev/shm dorowu/ubuntu-desktop-lxde-vnc
linux后台执行命令:&和nohup
当我们在终端或控制台工作时,可能不希望由于运行一个作业而占住了屏幕,因为可能还有更重要的事情要做,比如阅读电子邮件。对于密集访问磁盘的进程,我们更希望它能够在每天的非负荷高峰时间段运行(例如凌晨)。为了使这些进程能够在后台运行,也就是说不在终端屏幕上运行,有几种选择方法可供使用。
- &
当在前台运行某个作业时,终端被该作业占据;可以在命令后面加上& 实现后台运行。例如:sh test.sh &
适合在后台运行的命令有f i n d、费时的排序及一些s h e l l脚本。在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。不过,作业在后台运行一样会将结果输出到屏幕上,干扰你的工作。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:
1 | command > out.file 2>&1 & |
- 1
这样,所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中。
PS:当你成功地提交进程以后,就会显示出一个进程号,可以用它来监控该进程,或杀死它。(ps -ef | grep 进程号 或者 kill -9 进程号)
- nohup
使用&命令后,作业被提交到后台运行,当前控制台没有被占用,但是一但把当前控制台关掉(退出帐户时),作业就会停止运行。nohup命令可以在你退出帐户之后继续运行相应的进程。nohup就是不挂起的意思( no hang up)。该命令的一般形式为:
1 | nohup command & |
- 1
如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:
1 | nohup command > myout.file 2>&1 & |
1
使用了nohup之后,很多人就这样不管了,其实这样有可能在当前账户非正常退出或者结束的时候,命令还是自己结束了。所以在使用nohup命令后台运行命令之后,需要使用exit正常退出当前账户,这样才能保证命令一直在后台运行。ctrl + z
可以将一个正在前台执行的命令放到后台,并且处于暂停状态。Ctrl+c
终止前台命令。jobs
查看当前有多少在后台运行的命令。
jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated。但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识。2>&1解析
1 | command >out.file 2>&1 & |
- 1
- command>out.file是将command的输出重定向到out.file文件,即输出内容不打印到屏幕上,而是输出到out.file文件中。
- 2>&1 是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个&, 是让该命令在后台执行。
- 试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出.
关于ajax请求中cookie和header的问题
1 | 错误: |
博文链接:https://blog.csdn.net/menghuanzhiming/article/details/102736312
SpringBoot+Mybatis开启驼峰映射
mybatis自定义的SQL语句中,如select语句,如果数据库表的字段为驼峰命名,即如img_address这样的形式,那么select语句执行的结果会变成null。
解决办法是在配置文件中加上开启驼峰映射的配置信息。根据配置文件的类型分为以下两种:
1.在.properties文件中添加:
1 | mybatis.configuration.map-underscore-to-camel-case=true |
但如果已经在.properties中配置了mybatis.config-location=classpath:mybatis/mybatis-config.xml这样的语句,就应该使用下一种方式,即把配置信息写在.xml中。
2.在mybatis的配置文件,如mybatis-config.xml中进行配置:
1 | <configuration> |
方式一:通过springboot的配置文件application.yml
1 | mybatis: |
此方式是最简单的,但是要注意,通过springboot的配置文件配置mybatis的设置,则不能够再使用mybatis的配置文件,例如:下边代码中标红的两个设置不能同时存在,要么使用config-location指定mybatis的配置文件,在通过mybatis的配置文件配置相关设置,要么通过springboot配置文件的mybatis.configuration进行相关设置,二者只能选其一,否则会报错。
1 | mybatis: |
方式二:通过mybatis的配置文件
首先需要在springboot的配置文件application.yml中指定mybatis配置文件的位置。
1 | mybatis: |
然后在mybatis配置文件中进行设置
1 | <?xml version="1.0" encoding="UTF-8" ?> |
方式三:通过@Comfiguration注解和@Bean注解,向容器中添加ConfigurationCustomizer类型的组件,在ConfigurationCustomizer中进行设置
1 | @Configuration |
Vue3监听路由变化
1 | import { onBeforeRouteUpdate } from "vue-router"; |
1 | import { useRoute } from 'vue-router' |
Vue3简单博客项目后台开发笔记
开发博客后端的一些简单记录
坑:reactive
对于reactive的使
reactive可以直接使用无需配合toRefs 但是如果需要动态加载数据,这是必要的.!
Element UI
开发时建议全量导入,按需导入是不是出一些奇怪的问题,浪费时间
关闭eslint
开发中最好关闭这个鬼东西.
关闭方法:
在项目根目录下增加vue.config.js文件。
内容如下:
1 | // vue.config.js |
Axios跨域问题
http://xxhoz.com/2021/02/06/Vue-Axios%E8%B7%A8%E5%9F%9F%E8%AF%B7%E6%B1%82/
只能在开发环境下跨域!!!!!!
Vue3编程式路由
1 | import { useRouter } from 'vue-router' |
另外一个未尝试:
https://blog.csdn.net/weixin_48566243/article/details/114294364
Vue3路由参数获取
1 | import { onBeforeRouteUpdate } from "vue-router"; |
1 | import { useRoute } from 'vue-router' |
axios拦截器的使用
1 | axios.interceptors.request.use(config => { |
关于数据对接
最好开发时对应后端数据格式,不要图一时开发方便自定一个数据格式.否者后面改的头疼!!!!
v-md-editor的使用
这个简单 看官方文档:
http://ckang1229.gitee.io/vue-markdown-editor/zh/
路由守卫
这个很有用
1 | // 挂载路由导航守卫,to表示将要访问的路径,from表示从哪里来,next是下一个要做的操作 |
具体查看官方文档
错误解决
建议开发中打开控制台.尽可能解决所有警告!
Nginx解决跨域
前面跨域只在开发阶段有用.生成环境
nginx配置代理跨域:
1 | location ^~ /api{ |
完美解决