甜瓜游乐场汉化版18.0
休闲益智本文目录一览:
移动互联网在持续发展,前端开发技术也是在不断进步的,前端应用市场越来越广泛。租空型前端开发现在正在走向工程化发展,无论是大小公司企业,对前端开发的需求都是越来越大,也越来越专业了。总得来说,这个行业的前景是很广阔的.
所以学前端开发的亏弯前景是非常可观的,而且从事前端开发岗位也有很高的薪资待遇,基本上八九千起步,这还在不断攀升,具体的看个人的能力.
不过,要是想要在前端开发领域有一定的发展,还是需要先掌握好技术能力和积累一定的经验,不然对自己就业也没什么帮助。可以的话,找家机构就更好,有专业老师的指导,自己的学习也是事半功倍的,只是有些线下机构的情况不太可弊猜观,要注意点。
6月6日,不少网友发现,手机中的人人视频App无法正常安装或更新,还有用户反映,以前已经下载App的打开会发现账号没了,所有剧集也没了;随后,影视剧功能恢复,但App仍是下架状态。与此同时,在销梁微博上“人人视频下架”的消息冲上热搜。

打开腾讯新闻,查看更多图片
去App Store输入“人人视频”尝试下载,发现的确已经搜不到人人视频。人人视频安卓版 App 虽然并无影响,但“快看”相关内容同样下架。

人人视频发布公告表示,对于近期用户对快看内容的批评、建议,将虚心接受、积极改进,并响应《网络信息内容生态治理规定》及相关法律法规,即刻下线“快看”相关内容,针对问题内容进行坚决治理,对问题严重、影响恶劣的账号及违规内容,从严从重处置。

据悉,“快看”栏目由原来的“剧荒”升级而敏答来。
而据此前报道,“剧荒”栏目集合了用户自制短视频,系统利用用户观看亏拿运作品的历史智能推送用相似作品制作的短视频,如果看到感兴趣的,短视频下方链接可以直接跳转至正片,避免了二次搜索的麻烦。
简单来说也就是影视剧的剪辑片段,通常时长3-5分钟这种。
今年4月份,包括爱奇艺、腾讯视频、优酷、芒果tv等在内的70余家影视传媒单位发表联合声明,共同呼吁短视频平台和公众账号生产运营者尊重原创、保护版权,未经授权不得对相关影视作品实施剪辑、切条、搬运、传播等行为。
现在各视频平台都在有意进行加强审核,减少此类内容。“几分钟看一部电影”将成为历史。
而“快看”上的视频主要是影视作品的剪辑片段,那么此次下架或许就与行业抵制短视频侵权剪辑有关。
累计用户数量1.6亿,小米、百度等投资
公开资料显示,人人视频的前身是人人影视,而人人影视的前身是于2006年6月1日成立的YYeTs字幕组,它是国内最早创立、影响最大的字幕组之一。
最鼎盛时期,人人影视聚拢了2000多名兼职的字幕翻译,王思聪也曾是字幕组的人。
然而,随着版权保护力度的增强,人人影视屡遭封站。2014年,人人影视接受第三方投资转型做美剧社区,人人影视字幕组团队与新团队共同参与“人人美剧”项目的运营。人人影视将品牌和数据全部导给人人美剧,双方谋求共同发展。之后人人美剧更名人人视频。
2017年1月4日,人人影视官方微博发出题目为《人人视频与人人影视不是一家,已彻底无瓜葛》的文章,强调两家并无联系。

今年年初,注册用户超过800万,发布各类影视作品超过2万部的“人人影视字幕组”,因侵犯影视作品著作权被上海警方查了,人人影视彻底凉凉。
根据“警民直通车上海”消息,经过初步查证,“人人影视字幕组”网站和客户端各端口应用软件刊载影视作品20000余部(集),注册会员数量800余万。
上海警方历经三个月缜密侦查,最终抓获以梁某为首的犯罪嫌疑人14名,查处涉案公司3家,查获作案用手机20部和电脑主机、服务器12台,涉案金额1600余万元。
人人影视覆灭,人人视频则不断发展壮大。
QuestMobile发布的2019年上半年AppMAU(月活跃用户数)榜单中,人人视频已达到千万级规模。到了2020年10月,累计拥有用户数量1.6亿,平均月活量用户达4000万+。
2020年10月,人人视频运营公司上海众多美网络科技有限公司与重庆南岸区政府、重庆经开区管委会、中国信息通信研究院西部分院在渝签署战略合作协议,宣布人人视频总部基地落户重庆市南岸区。
人人视频董事长周为民介绍,人人视频将把整体经营业务转移至重庆,并计划以重庆本地公司作为上市主体在国内或国外挂牌上市。接下来,人人视频将加大网络电视剧、网络大电影制作,预计3-5年内,打造50亿元以上产值规模的重庆特色数字内容产业园。
今年2月,人人视频刚刚拿到了美好资本股权融资。而自2015年以来,人人视频已经经过了6轮融资,李开复的创新工场、百度视频、小米等都曾参与过融资。
值得注意的是,人人视频此前就曾经被多次处罚过。
工商资料显示,早在2016年7月27日,上海市文化市场行政执法总队就曾因版权问题对人人视频依法作出行政处罚。2018年,人人视频也先后被罚款2次,并给予警告。
2019年12月,工信部向社会通报了41家存在侵害用户权益行为App企业的名单,人人视频也在其中。人人视频因存在私自收集个人信息、私自共享给第三方、过度索取权限问题,受到工业和信息化部信息通信管理局通报被要求整改。
2020年1月3日,人人视频还未整改完毕,便被工信部强制下架了。人人视频当时解释是因为“应用内存在部分早期技术问题未解决,导致本次应用下架”。同时,人人视频也表示将积极配合工信部,完成整改,提供合法合规的版本。
人人视频版权问题何解?
“人人影视字幕组”彻底凉了!2月3日,这则消息让剧迷们奔走相告,大呼惋惜。
当日,上海市公安局召开新闻发布会,通报了近期侦破的案件,其中包括“人人影视字幕组”网站涉嫌侵犯影视作品著作权案,涉案金额为1600余万元,14人被抓。
而这次被下架的人人视频,跟人人影视无论从名字、logo还是服务内容都很相似,两者是否有何渊源?
从公开报道来看,它们之前确实有过“纠葛”,但现在早就没啥关系了:2014年,在被美国电影协会列入盗版下载黑名单之后关停网站的人人影视,接受第三方投资转型做美剧社区,人人影视字幕组团队与新团队共同参与“人人美剧”项目的运营。人人影视将品牌和数据全部导给人人美剧,双方谋求共同发展。之后人人美剧更名人人视频。
2017年1月4日,人人影视官方微博发出题目为《人人视频与人人影视不是一家,已彻底无瓜葛》的文章,强调两家并无联系。
正如上文所述,人人视频宣布落户重庆,并披露上市计划后,外界最大的疑问就在于,版权问题何解?
公开资料显示,人人视频多次因为违反互联网视听节目服务管理规定而受到处罚。其中2020年1月,因未按要求完成整改,被工信部要求在应用商店下架。
此外,与爱奇艺等国内多家视频平台也均发生过版权纠纷。根据企查查的数据,其隶属的上海众多美网络科技有限公司,自身风险高达20余条,其中不少是版权纠纷。
Java11升级Java17备忘录

下塘烧饼
白头不厌穷编码,只影孤灯两卷书。
来自专栏一只老程序猿
一、概述
Java17是目前Java最新的LTS版本,SpringBoot从2.5.5开始正式支持Java17,并且计划从3.0版本开始,Java版汪侍首本要求最低是Java17。
为了顺应Java及其生态的发展,最近对一套JavaWeb开发框架做了版本升级,主要是Java版本和Springboot版本的升级,包括:
Java版本从openJDK11升级到openJDK17
springboot版本从2.1.11升级到2.7.4
本次升级相比从困数Java8升级到Java11要简单很多,基本没遇到什么问题。
Java8到Java11之间有Java9这个变化很大的拦路虎,包括但不限于:移除了一些以前集成在jdk的lib中的依赖包,引入模块化导致某些内部API不可用,类加载机制变化导致一些第三方依赖包版本不兼容,等等。
而从Java11到Java17,中间并没有Java9那样巨大的变化,只有Java16和Java17中有一些增强Java内部封装的新特性,可能会导致底层类库依赖包的老版本不能兼容Java17。
关于Java8升级Java11的工作,可以参考我以前的文章:
java - Java8升级Java11备忘录_个人文章 - SegmentFault 思否
另外,本篇文章主要讲如何从Java11升级到Java17,以及升级过程中遇到的一些问题。如果想看Java11到Java17有哪些新特性,可以参考我以前的另一片文章:
下塘烧饼:java17相对java11的新特性
二、升级谈败工作内容
升级工作内容大致如下:
2.1 安装openJDK17及其对应的IDEA
这里选择的是eclipse的Adoptium社区版本:
OpenJDK17U-jdk_x64_linux_hotspot_17.0.3_7.tar.gz
下载地址:
更多版本与下载地址请参考文章:
下塘烧饼:java17相对java11的新特性
安装很简单,解压缩到指定目录即可。
只是开发的话,JAVA_HOME与PATH等环境变量不是一定要设置的,比如我这里的环境有多个JDK版本,只要在IDE中添加新的JDK即可。
IDEA的话,使用2021.2.4以上版本即可支持Java17,在其sdk中加入刚刚安装好的JDK目录:
用IDEA任意打开一个java工程,在其Project Structrue - Platform settings - SDKs中添加JDK17目录。
2.2 配置本地Maven
在本地Maven的配置文件中添加新的JDK17的profile,比如我这里的配置文件是/opt/apache-maven-3.5.0/conf/settings.xml,打开并在其中添加:
profiles ... profile idopenJDK17/id activation jdk17/jdk /activation properties JAVA_HOME/usr/java/jdk-17.0.3+7//JAVA_HOME JAVA_VERSION17/JAVA_VERSION maven.compiler.source17/maven.compiler.source maven.compiler.target17/maven.compiler.target maven.compiler.compilerVersion17/maven.compiler.compilerVersion /properties repositories repository idXXX-Repository/id nameXXX Maven Repository/name url;/url snapshots enabledtrue/enabled /snapshots /repository /repositories pluginRepositories pluginRepository idXXX-Repository/id nameXXX Maven Repository/name url;/url snapshots enabledtrue/enabled /snapshots /pluginRepository /pluginRepositories /profile /profiles
JAVA_HOME是本地JDK安装目录。
repository与pluginRepository用来配置maven仓库地址,之后在IDE中启用这里配置的profile。这样maven拉取jar包时,会优先从这里配置的maven仓库拉取,拉取不到时再去中央仓库拉。
配置好settings.xml后,在各个java工程中启用新的profile:
首先在File - Settings - Maven中确定maven及其配置文件目录:
然后在IDEA的maven插件中选择jdk17的profile:
2.3 修改父工程的pom版本控制
升级对象是一套JavaWeb开发框架,有自己的父工程来控制依赖包的版本,在决定升级Java版本与Springboot版本后,父工程的pom文件中的相关依赖包版本需要更新。
首先是父工程自己的版本需要升级,这样仍然依赖老版本父工程的java工程就不会升级相关版本,只有依赖了新版本父工程的java工程才会升级相关版本。
artifactIdparent-xxx/artifactId version2.0.0/version
这里假定老版本是1.x.x,新版本是2.0.0。
实际上父工程的pom是在升级过程中不断修改的,为了不影响使用该父工程的项目开发,你需要与相关开发人员约定好在升级完成后再尝试使用新版本的父工程。
然后修改基本属性与spring相关依赖包的版本,篇幅原因这里只给出版本发生变化的依赖包的修改后版本号,dependency配置略过:
properties !-- 基本属性 -- project.build.sourceEncodingUTF-8/project.build.sourceEncoding project.reporting.outputEncodingUTF-8/project.reporting.outputEncoding java.version17/java.version !-- spring相关版本 -- spring-boot.version2.7.4/spring-boot.version spring-boot-admin.version2.7.4/spring-boot-admin.version spring-cloud.version2021.0.4/spring-cloud.version spring-cloud-alibaba.version2021.0.1.0/spring-cloud-alibaba.version mybatis-spring-boot-starter.version2.2.2/mybatis-spring-boot-starter.version pagehelper-spring-boot-starter.version1.4.5/pagehelper-spring-boot-starter.version !-- 插件版本 -- spring-boot-maven-plugin.version2.7.4/spring-boot-maven-plugin.version mybatis-generator-maven-plugin.version1.4.1/mybatis-generator-maven-plugin.version !-- 其他依赖包版本 -- lombok.version1.18.24/lombok.version /properties
升级后的测试并不充分,这里列出的发生版本变化的依赖包可能并不全面。
如果在编译或运行时发现有某个依赖包报错,说某个jdk的module因为没有导出而无法访问的错误: cannot access class xxx (in module jdk.xxx) because module jdk.xxx does not export xxx to xxx,那么就基本可以确定这个依赖包版本较老不兼容Java17。
解决方法很简单,在当前这个时间点,基本上所有的第三方依赖包都已经有兼容Java17的较新的版本,直接去maven中央仓库找一个新版本下载,就能解决问题。
比如上面的lombok版本升级到了1.18.24,就是为了解决编译时发生的上述不兼容的错误。
另外,如果父工程中还约定了很多自用的通用工程的版本,那么这里需要确保这些通用工程的版本范围在新老版本中的定义没有冲突。
例如老版本的父工程中定义了一些通用工程的版本:
lib-xxx.version[1.0.0-RELEASE,2.0.0-RELEASE)/lib-xxx.version
这里的lib-xxx是这套JavaWeb开发框架中的一个通用库,在老版本的父工程中约定它的版本范围是[1.0.0-RELEASE,2.0.0-RELEASE),即从1.0.0-RELEASE(包含)到2.0.0-RELEASE(不包含)。那么新版本的父工程,对它的版本范围约定就是[2.0.0-RELEASE,3.0.0-RELEASE)。
这样约定的目的是,如果有一些java工程仍然要使用老版本的父工程(假定由于种种原因,只能用Java11与Springboot2.1.x 。。。),那么它就不会依赖2.0.0-RELEASE及其以上版本的lib-xxx;而一旦依赖了新版本的父工程,就只会依赖2.0.0-RELEASE及其以上版本的lib-xxx。
最后要注意,如果在老版本(这里就是Java11和Springboot2.1.11)上还有新的应用或需求变更要开发,那么需要在代码管理库中切出一个新的分支来做升级的工作,并约定好各自的版本范围,比如采用不同的主版本号。
2.4 单个Java工程的版本升级
在前面的2.1到2.3准备工作完成之后,就可以对java应用工程做版本升级了。
首先打开一个java工程,确认maven的目录与配置文件是否正确,并将maven插件的profile选择到jdk17,这一步已在步骤2.2中示意。
然后修改工程依赖的父工程版本为2.3中修改后的父工程版本。
parent groupIdxxx/groupId artifactIdparent-xxx/artifactId version2.0.0/version /parent
然后先使用maven插件刷新pom依赖,顺利的话,可以在maven插件中看到新的依赖包版本:
pom依赖刷新之后,再来修改工程的idea配置中的java版本,打开Project Structrue,依次修改或确认java版本:
然后我们就可以对工程进行编译,检查有没有编译错误或警告。
考虑到devops的需要,你可能需要一个maven编译脚本,要注意java版本,如下所示:
#!/bin/bash export JAVA_HOME=/usr/java/jdk-17.0.3+7 mvn -version mvn clean install package
注意这里指定了JAVA_HOME,maven编译时会用到这个环境变量,因此指定为JDK17的安装目录。本地环境安装有多个JDK版本时要特别注意这一点。
如果是springboot工程,编译成功之后就可以启动服务:
#!/bin/bash JAVA_HOME=/usr/java/jdk-17.0.3+7 JAR_PATH=$(find target -name "*.jar") ${JAVA_HOME}/bin/java -jar "${JAR_PATH}"
2.5 编译与运行时遇到的问题
在编译工程以及启动springboot服务时,可能会遇到以下问题。
2.5.1 JDK模块内API未导出问题
前面说过,Java16和Java17中有一些增强Java内部封装的新特性,该特性加强了对一些以前暴露出来但其实很不安全的关键API的封装,即你不再能从外部访问这些内部API。而java的生态圈中有很多底层的类库比如lombok在以前的版本中会调用到这些内部API。那么在Java17以后将不再能调用它们,所以会有不兼容的问题。
这种问题的典型错误信息:
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project api-brood-base: Fatal error compiling: java.lang.IllegalAccessError: class lombok.javac.apt.LombokProcessor (in unnamed module @0x5740ff5e) cannot access class com.sun.tools.javac.processing.JavacProcessingEnvironment (in module jdk.compiler) because module jdk.compiler does not export com.sun.tools.javac.processing to unnamed module @0x5740ff5e - [Help 1]
这里的关键信息就是cannot access class xxx (in module jdk.xxx) because module jdk.xxx does not export xxx to xxx,一旦看到这句错误信息,就知道这是由于JDK加强了内部API的封装所导致的不兼容问题。
解决起来很简单,找个新版本就行了。以lombok为例,升级到版本1.18.24即可。
其他类库的包也有可能出现类似的问题,解决方法一样,换用更新的兼容Java17的版本即可。
2.5.2 redisTemplate版本不兼容
如果使用了spring的redisTemplate,那么有可能出现版本不兼容,包括:
redisTemplate.delete方法编译错误,方法参数的泛型发生了变化。
// 版本升级前编译OK,升级后编译错误 redisTemplate.delete(CollectionUtils.arrayToList(key)); // 版本升级后修改如下 redisTemplate.delete(Arrays.asList(key));
GenericObjectPoolConfig的setMaxWaitMillis被废弃不再推荐使用,用setMaxWait代替:
GenericObjectPoolConfig? genericObjectPoolConfig = new GenericObjectPoolConfig(); ... // genericObjectPoolConfig.setMaxWaitMillis(redisProps.getPool().getMaxWait()); genericObjectPoolConfig.setMaxWait(Duration.ofMillis(redisProps.getPool().getMaxWait()));
2.5.3 jackson版本不兼容
spring默认使用的json工具类库jackson,它的ObjectMapper的enableDefaultTyping被废弃不再推荐使用,使用activateDefaultTyping代替
具体代码如下所示:
ObjectMapper om = new ObjectMapper(); // om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL); om.activateDefaultTyping(om.getPolymorphicTypeValidator(), ObjectMapper.DefaultTyping.NON_FINAL);
2.5.4 循环依赖问题
springboot的新版本默认不再支持bean的循环依赖,因此项目中有循环依赖的bean的话,会报错,例如:
The dependencies of some of the beans in the application context form a cycle: xxxxxxxxx ┌─────┐ | xxxService1 (field private com.gcsoft.brood.sentry.service.XxxService2 com.gcsoft.brood.sentry.service.xxxService1.xxxService2) ↑ ↓ | xxxService2 (field private com.gcsoft.brood.sentry.service.XxxService1 com.gcsoft.brood.sentry.service.XxxService2.xxxService1) └─────┘ Action: Relying upon circular references is discouraged and they are prohibited by default. Update your application to remove the dependency cycle between beans. As a last resort, it may be possible to break the cycle automatically by setting spring.main.allow-circular-references to true.
最好的对应方式是消去bean之间的循环依赖,否则就需要显式声明允许bean的循环依赖,在application.yml中加入属性:
spring: main: allow-circular-references: true
2.5.5 缺少spring.config.import配置
如果在pom工程中依赖了springcloud的相关jar,但并没有使用springcloud相关的config配置,那么在启动springboot服务时可能会失败:
No spring.config.import property has been defined Action: Add a spring.config.import=configserver: property to your configuration. If configuration is not required add spring.config.import=optional:configserver: instead. To disable this check, set spring.cloud.config.enabled=false or spring.cloud.config.import-check.enabled=false.
按照提示,在application.yml中加入属性:
spring: cloud: config: enabled: false
2.5.6 jetty版本冲突
springboot版本升级后,内嵌的jetty版本也升级了。由于某些第三方jar使用了低版本的jetty的某些包,即使springboot没有使用jetty,也依然会在运行时发生jetty的不兼容问题:
java.lang.ClassNotFoundException: org.eclipse.jetty.server.RequestLog$Writer
这里可以选择升级第三方jar。
或者直接去除第三方jar对jetty的依赖:
dependency groupIdorg.apache.hive/groupId artifactIdhive-jdbc/artifactId version${hive.version}-${cdh.version}/version exclusions exclusion artifactIdjetty-all/artifactId groupIdorg.eclipse.jetty.aggregate/groupId /exclusion /exclusions /dependency
2.6 docker镜像
在各个工程完成升级,编译成功,并简单运行OK之后,开始做docker镜像的升级工作。
毕竟现在都在云端跑服务了。。。
这里从Docker Hub上找了与开发使用的openJDK版本一致的docker镜像,也是由eclipse的Adoptium社区提供的。
其实没有必要,其他openJDK17版本的docker镜像也是一样的,单纯的强迫症而已。。。
docker pull eclipse-temurin:17.0.3_7-jdk-alpine
对应docker hub地址:
Docker Hub
在这个openJDK17镜像的基础上,修改了时区与语言等信息,安装了bash与telnet,DockerFile如下:
# 指定基础镜像,在其上进行定制(这里是 eclipse-temurin:17.0.3_7-jdk-alpine 的镜像) FROM eclipse-temurin:17.0.3_7-jdk-alpine # 定制环境变量 ENV TIME_ZONE=Asia/Shanghai LANG=en_US.UTF-8 LANGUAGE=en_US.UTF-8 LC_ALL=en_US.UTF-8 # RUN在build镜像时执行,每RUN一次就会构成一层新的镜像。 # 因此有多个命令要执行时,用""连接写在一起。 RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g' /etc/apk/repositories apk add --no-cache tzdata echo "${TIME_ZONE}" /etc/timezone ln -sf /usr/share/zoneinfo/${TIME_ZONE} /etc/localtime apk add --no-cache bash bash-doc bash-completion busybox-extras
原始的eclipse-temurin:17.0.3_7-jdk-alpine有335M,添加了tzdata,bash,busybox-extras(telnet)之后,大小是340.8M。。。完整的JDK镜像就是这么大。。。如果生产环境不需要JDK,那么可以用JRE作成的镜像,会小不少,但是缺失了很多JDK工具。
用这个DockerFile做成一个新的openJDK17镜像,命名为xxx/base-openjdk17:jdk-17.0.3_001,而各个springboot工程的DockerFile如下所示:
# 指定基础镜像 FROM xxx/base-openjdk17:jdk-17.0.3_001 # JDK11开始支持: -XX:+UseContainerSupport 使JVM能够感知容器资源, -XX:InitialRAMPercentage 初期容器内存占比, -XX:MaxRAMPercentage 最大容器内存占比 ENV JAVA_OPTS="-XX:+UseContainerSupport -XX:InitialRAMPercentage=50 -XX:MaxRAMPercentage=80" # 复制上下文目录下的target/*.jar 到容器里 ADD target/*.jar app.jar # 指定容器启动程序及参数 ENTRYPOINT "CMD" ENTRYPOINT java ${JAVA_OPTS} -jar /app.jar
该DockerFile位于springboot工程根目录下。
打进了springboot fat jar的镜像会变得更大,一般都会有400M以上。。。
三、小结
总的来说,Java11到Java17的升级比较顺利,只有少数依赖包对应版本需要升级。另外就是springboot的升级可能导致需要添加少量配置,比如显式允许bean的循环依赖
联系邮箱:wanyiw24@163.com(三个工作日内处理)
备案号:浙ICP备2023010491号-1