Windows 编译CEF源码详细记录

背景

默认的CEF不支持音视频功能,需要下载源码将ffmpeg开关打开,再进行编译。

Linux编译参考:
《Linux CEF源码下载编译详细记录》

创建目录结构

code/automate/automate-git.py   <-- CEF build scriptchromium_git/cef/              <-- CEF source checkoutchromium/src/            <-- Chromium source checkoutupdate.[bat|sh]   <-- Bootstrap script for automate-git.pydepot_tools/        <-- Chromium build tools

powershell中使用命令一键创建所需文件夹

mkdir -p CEF\automate,CEF\chromium_git

设置网络环境

可从clash猫 常规-端口那里打开已经设置好的代理的终端,或者手动设置终端代理

$env:HTTP_PROXY="http://127.0.0.1:7890"
$env:HTTPS_PROXY="http://127.0.0.1:7890"

查看代理

ls env:*|findstr proxy(PROXY)PS E:\CEF\depot_tools> ls env:*|findstr proxy
https_proxy                    http://127.0.0.1:7890
http_proxy                     http://127.0.0.1:7890

设置git代理(可选),自测不需要。

git config --global http.proxy http://127.0.0.1:7890
git config --global https.proxy http://127.0.0.1:7890

下载脚本

下载depot_tools

在CEF目录下,下载depot_tools

git clone https://chromium.googlesource.com/chromium/tools/depot_tools

depot_tools目录下执行update_depot_tools脚本,等待下载完成,这个阶段时间会有点长,会下载大约1GB的文件。

PS E:\CEF\depot_tools> .\update_depot_tools.bat

下载完成后,将其设置为环境变量

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T836StWD-1691654584186)(../AppData/Roaming/Typora/typora-user-images/image-20230802164755820.png)]

注意:这里环境变量位置似乎要在python、git之上。

不过我推荐临时设置环境变量的方式:

查看powershell环境变量

$env:path -split“;”

在powershell设置环境变量,这里是放在了所有Path环境变量的最前面

$env:Path="E:\CEF\depot_tools;$env:Path;"

cmd设置环境变量

set path=E:\CEF\depot_tools;%path%

查看环境变量:

set path

文档好多都是set命令,推荐使用cmd命令行。

下载automate-git.py

下载 automate-git.py 脚本到 CEF\automate\automate-git.py,可使用powershell命令下载,或者手动下载。

Start-BitsTransfer -Source "https://bitbucket.org/chromiumembedded/cef/raw/master/tools/automate/automate-git.py" -Destination "automate-git.py"

在chromium_git目录下创建update.bat脚本:

set GN_DEFINES=is_component_build=true
set GN_ARGUMENTS=--ide=vs2022 --sln=cef --filters=//cef/*
python ..\automate\automate-git.py --download-dir=c:\code\chromium_git --depot-tools-dir=c:\code\depot_tools --no-distrib --no-build
  • –branch 表示要下载哪个版本的代码,CEF 每个版本都有固定的分支,在 CEF 项目页查看分支名称指定即可。

  • –no-build 表示只下载代码而不编译,这里只为下载代码,我们还要修改支持多媒体的参数,所以不进行编译。

  • –no-distrib 不执行打包项目,这里只为下载代码,我们还要修改支持多媒体的参数,所以不进行打包。

  • –force-clean 如果你曾经执行过这个脚本,可能会出错,则加上这个参数,它执行清理残留文件(你也可以手动在 chromium 源码目录执行 git clean -xdf 来清理目录中的多余内容)。如果没有一次性下载成功而再次执行下载命令时,需要带上这个参数来清理一些信息,否则检出会失败

  • –force-clean-deps 编译老版本的时候会碰到下载第三方依赖库失败,碰到了可以加下这个

  • –no-depot-tools-update 如果工具包之前下载过了可以加上,就不升级工具包了,第一次下载不加

  • –no-update 编译时用,不更新直接编译

  • –no-debug-build 编译时用,不编译debug只要release

  • –x64-build 构建64位的版本

设置Boto代理(可选)

这一步可能有用

[Boto]
proxy = 127.0.0.1
proxy_port = 7890

创建boto.cfg文件,在命令行设置环境变量,set NO_AUTH_BOTO_CONFIG=E:\CEF\boto.cfg

执行脚本

运行update.bat:

PS E:\CEF\chromium_git> ./update.batE:\CEF\chromium_git>set GN_DEFINES=is_component_build=trueE:\CEF\chromium_git>set GN_ARGUMENTS=--ide=vs2022 --sln=cef --filters=//cef/*E:\CEF\chromium_git>python ..\automate\automate-git.py --download-dir=E:\CEF\chromium_git --depot-tools-dir=E:\CEF\depot_tools --no-distrib --no-build
--> Download Directory: E:\CEF\chromium_git
--> Depot Tools Directory: E:\CEF\depot_tools
--> Updating depot_tools

等待。。。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7bJniKOQ-1691654584187)(../AppData/Roaming/Typora/typora-user-images/image-20230807210431222.png)]

但这里我老是卡在这个地方:

SyntaxError: unexpected EOF while parsing
Traceback (most recent call last):File "..\automate\automate-git.py", line 1232, in <module>run("gclient revert --nohooks", chromium_dir, depot_tools_dir)File "..\automate\automate-git.py", line 67, in runargs, cwd=working_dir, env=env, shell=(sys.platform == 'win32'))File "E:\code\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python\bin\lib\subprocess.py", line 190, in check_callraise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command '['gclient', 'revert', '--nohooks']' returned non-zero exit status 1

我尝试了好几种:

  1. 将目录CEF改为code,与Wiki文档保持一致,失败
  2. 尝试修改update.bat,失败
  3. 尝试PowerShell换为cmd执行update.bat,失败

然后我换用VS的命令行工具x64 Native Tools Command Prompt for VS 2022执行,没想到成功了,能开始下载第三方库了

set http_proxy=http://127.0.0.1:7890 & set https_proxy=http://127.0.0.1:7890
update.bat

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IDoIp3zc-1691654584188)(../AppData/Roaming/Typora/typora-user-images/image-20230808095743525.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-T7witlQu-1691654584188)(../AppData/Roaming/Typora/typora-user-images/image-20230808124425879.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bUsjAPo9-1691654584189)(../AppData/Roaming/Typora/typora-user-images/image-20230808124845010.png)]

下载成功!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CgXnaSuv-1691654584189)(../AppData/Roaming/Typora/typora-user-images/image-20230808134538909.png)]

问题处理

  • RPC failed; curl 92 HTTP/2 stream 3 was not closed cleanly before end of the underlying stream
1>________ running 'git -c core.deltaBaseCacheLimit=2g clone --no-checkout --progress https://chromium.googlesource.com/chromium/src.git E:\CEF\chromium_git\chromium\_gclient_src_uhqf8ic3' in 'E:\CEF\chromium_git\chromium' attempt 2 / 2
1>Cloning into 'E:\CEF\chromium_git\chromium\_gclient_src_uhqf8ic3'...
1>remote: Finding sources: 100% (1558/1558)           objects: 1
1>error: RPC failed; curl 92 HTTP/2 stream 3 was not closed cleanly before end of the underlying stream
1>error: 59273 bytes of body are still expected
1>fetch-pack: unexpected disconnect while reading sideband packet
1>fatal: early EOF
1>fatal: fetch-pack: invalid index-pack output

一般是下载超时

  • ‘gclient’, ‘revert’, ‘–nohooks’
src (ERROR)
----------------------------------------
[0:00:00] Started.
----------------------------------------
Traceback (most recent call last):File "E:\CEF\depot_tools\metrics.py", line 301, in print_notice_and_exityieldFile "E:\CEF\depot_tools\gclient.py", line 3669, in <module>sys.exit(main(sys.argv[1:]))File "E:\CEF\depot_tools\gclient.py", line 3655, in mainreturn dispatcher.execute(OptionParser(), argv)File "E:\CEF\depot_tools\subcommand.py", line 252, in executereturn command(parser, args[1:])File "E:\CEF\depot_tools\gclient.py", line 3256, in CMDrevertreturn client.RunOnDeps('revert', args)File "E:\CEF\depot_tools\gclient.py", line 2129, in RunOnDepswork_queue.flush(revision_overrides,File "E:\CEF\depot_tools\gclient_utils.py", line 1016, in flushreraise(e[0], e[1], e[2])File "E:\CEF\depot_tools\gclient_utils.py", line 70, in reraiseraise valueFile "E:\CEF\depot_tools\gclient_utils.py", line 1093, in runself.item.run(*self.args, **self.kwargs)File "E:\CEF\depot_tools\gclient.py", line 1161, in runself.ParseDepsFile()File "E:\CEF\depot_tools\gclient.py", line 888, in ParseDepsFiledeps_to_add = self._deps_to_objects(File "E:\CEF\depot_tools\gclient.py", line 723, in _deps_to_objectscached_conditions[condition] = gclient_eval.EvaluateCondition(File "E:\CEF\depot_tools\gclient_eval.py", line 662, in EvaluateConditionreturn _convert(main_node)File "E:\CEF\depot_tools\gclient_eval.py", line 592, in _convertreturn EvaluateCondition(File "E:\CEF\depot_tools\gclient_eval.py", line 662, in EvaluateConditionreturn _convert(main_node)File "E:\CEF\depot_tools\gclient_eval.py", line 628, in _convertvalue = _convert(node.operand)File "E:\CEF\depot_tools\gclient_eval.py", line 620, in _convertbool_values.append(_convert(value))File "E:\CEF\depot_tools\gclient_eval.py", line 644, in _convertleft = _convert(node.left)File "E:\CEF\depot_tools\gclient_eval.py", line 592, in _convertreturn EvaluateCondition(File "E:\CEF\depot_tools\gclient_eval.py", line 564, in EvaluateConditionmain_node = ast.parse(condition, mode='eval')File "C:\Users\Listening\.vpython-root\store\cpython-e6tenrlsesftvg6k08ajgkk7b4\contents\bin\Lib\ast.py", line 47, in parsereturn compile(source, filename, mode, flags,File "<unknown>", line 0^
SyntaxError: unexpected EOF while parsing
Traceback (most recent call last):File "E:\CEF\automate\automate-git.py", line 1232, in <module>run("gclient revert --nohooks", chromium_dir, depot_tools_dir)File "E:\CEF\automate\automate-git.py", line 66, in runreturn subprocess.check_call(^^^^^^^^^^^^^^^^^^^^^^File "C:\Users\Listening\AppData\Local\Programs\Python\Python311\Lib\subprocess.py", line 413, in check_callraise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command '['gclient', 'revert', '--nohooks']' returned non-zero exit status 1.

此问题难以处理,只能多尝试几次,或者修改update.bat参数、换终端尝试。

修改ffmpeg配置文件

chromium_git\chromium\src\third_party\ffmpeg\chromium\config\Chromium\win-msvc\x64\config.hchromium_git\chromium\src\third_party\ffmpeg\chromium\config\Chromium\win\x64\config_components.h

以防万一,这两个地方都将CONFIG_SIPR_PARSER 宏开关启用,改为1

执行cef脚本

chromium_git\chromium\src\cef\下创建脚本create.bat

set GN_DEFINES=ffmpeg_branding=Chrome proprietary_codecs=true is_official_build=true
set GN_ARGUMENTS=--ide=vs2022 --sln=cef --filters=//cef/*call cef_create_projects.bat

这一行是为了激活ffmpeg

// 激活 ffmpeg 内部解码器
set GN_DEFINES=ffmpeg_branding=Chrome proprietary_codecs=true is_official_build=true

然后执行create.bat

遇到错误:

Exception: No supported Visual Studio can be found. Supported versions are: 17.0 (2022), 16.0 (2019), 15.0 (2017).
ERROR at //build/config/win/visual_studio_version.gni:28:7: Script returned non-zero exit code.exec_script("../../vs_toolchain.py", [ "get_toolchain_dir" ], "scope")^----------
Current dir: E:/CEF/chromium_git/chromium/src/out/Debug_GN_x64/
Command: E:/CEF/depot_tools/bootstrap-2@3_8_10_chromium_26_bin/python3/bin/python3.exe E:/CEF/chromium_git/chromium/src/build/vs_toolchain.py get_toolchain_dir
Returned 1.
See //third_party/angle/gni/angle.gni:54:5: whence it was imported.import("//build/config/win/visual_studio_version.gni")^----------------------------------------------------
See //ui/accessibility/BUILD.gn:16:3: whence it was imported.import("//build/toolchain/win/midl.gni")^--------------------------------------
See //BUILD.gn:144:7: which caused the file to be included."//ui/accessibility:accessibility_unittests",

因为我的 Microsoft Visual Studio 不是默认安装路径,我安装在D盘,修改create.bat脚本,加上

set GYP_MSVS_VERSION=2022
set GYP_MSVS_OVERRIDE_PATH=D:\Program Files\Microsoft Visual Studio\2022\Community
set WINDOWSSDKDIR=C:\Program Files (x86)\Windows Kits\10

即create.bat:

set GN_DEFINES=ffmpeg_branding=Chrome proprietary_codecs=true is_official_build=trueset GYP_MSVS_VERSION=2022
set GYP_MSVS_OVERRIDE_PATH=D:\Program Files\Microsoft Visual Studio\2022\Community
set WINDOWSSDKDIR=C:\Program Files (x86)\Windows Kits\10set GN_ARGUMENTS=--ide=vs2022 --sln=cef --filters=//cef/*
call cef_create_projects.bat

然后就生成成功了,同时生成了Debug、Release的 x86、 x64版本,可以在chromium_git\chromium\src\out看到对应的产物

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZuN1ZZ0S-1691654584190)(../AppData/Roaming/Typora/typora-user-images/image-20230808154807626.png)]

问题处理

由于环境变量设置错误,导致开启音视频的环境变量被覆盖。所以我删掉out下的文件,重新编译了一次,结果这次,提示需要pgo_profiles文件,并且生成的文件夹多了后缀带_sandbox的。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0SbYwQFe-1691654584190)(../AppData/Roaming/Typora/typora-user-images/image-20230809144017271.png)]

如果遇到pgo_profiles的报错,可以按照提示进行修改

Generating CEF project files...
Generating Visual Studio projects took 2203ms
Done. Made 17846 targets from 3213 files in 12500ms
Applying issue #1999 fix to E:\CEF\chromium_git\chromium\src\out\Debug_GN_x64\obj\cef\libcef.ninja
Traceback (most recent call last):File "E:/CEF/chromium_git/chromium/src/tools/update_pgo_profiles.py", line 154, in <module>sys.exit(main())File "E:/CEF/chromium_git/chromium/src/tools/update_pgo_profiles.py", line 150, in mainreturn args.func(args)File "E:/CEF/chromium_git/chromium/src/tools/update_pgo_profiles.py", line 106, in _get_profile_pathraise RuntimeError(
RuntimeError: requested profile "E:\CEF\chromium_git\chromium\src\chrome\build\pgo_profiles\chrome-win32-5672-1683023364-7247966391e939f36249c5509b49406c09455a6d.profdata" doesn't exist, please make sure "checkout_pgo_profiles" is set to True in the "custom_vars" section of your .gclient file, e.g.:
solutions = [{"name": "src",# ..."custom_vars": {"checkout_pgo_profiles": True,},},
],
and then run "gclient runhooks" to download it. You can also simply disable the PGO optimizations by setting |chrome_pgo_phase = 0| in your GN arguments.
ERROR at //build/config/compiler/pgo/BUILD.gn:81:23: Script returned non-zero exit code.pgo_data_path = exec_script("//tools/update_pgo_profiles.py",^----------
Current dir: E:/CEF/chromium_git/chromium/src/out/Release_GN_x86/
Command: E:/CEF/depot_tools/bootstrap-2@3_8_10_chromium_26_bin/python3/bin/python3.exe E:/CEF/chromium_git/chromium/src/tools/update_pgo_profiles.py --target win32 get_profile_path
Returned 1.
See //build/config/BUILDCONFIG.gn:352:3: which caused the file to be included."//build/config/compiler/pgo:default_pgo_flags",^----------------------------------------------

我这里尝试运行gclient runhooks但是还是提示不存在,所以我这里将其禁用了,在create.bat的第一行追加chrome_pgo_phase = 0

set GN_DEFINES=ffmpeg_branding=Chrome proprietary_codecs=true is_official_build=true chrome_pgo_phase=0

编译

cd 到CEF/chromium_git/chromium/src路径下执行ninja命令

cd ~/CEF/chromium_git/chromium/src
ninja -C out/Release_GN_x64 cef

开始编译,我这里需要编译56602个文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oOcIzu2f-1691654584191)(../AppData/Roaming/Typora/typora-user-images/image-20230808155244690.png)]

然后再编译sandbox

ninja -C out/Release_GN_x64_sandbox cef_sandbox

问题处理

  1. UnicodeDecodeError: ‘gbk’ codec can’t decode byte 0x92 in position 231: illegal multibyte sequence

遇到这个错误好像不影响编译,最终也能编译成功。但不确定是否有缺陷。

[31649/56602] ACTION //chrome/browser/resources/settings:build_bundle(//build/toolchain/win:win_clang_x64)
Exception in thread Thread-2:
Traceback (most recent call last):File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\threading.py", line 932, in _bootstrap_innerself.run()File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\threading.py", line 870, in runself._target(*self._args, **self._kwargs)File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\subprocess.py", line 1370, in _readerthreadbuffer.append(fh.read())
UnicodeDecodeError: 'gbk' codec can't decode byte 0x92 in position 231: illegal multibyte sequence

来自网络解决方法:

Windows下默认是gbk,导致读取文件时出错,这里在cmd里改为UTF-8编码,设置全局环境UTF-8

set PYTHONLEGACYWINDOWSSTDIO=utf8
set PYTHONIOENCODING=utf8
set PYTHONUTF8=1

cmd终端编码修改为UTF-8,chcp会显示当前的编码编号

  • 936 GBK
  • 65001 UTF-8
chcp 65001

编译了X86的测试,发现没有报错了。

解决此问题时,最好清理一下

ninja -C out/Release_GN_x64 -t clean
  1. 第二次编译时,我提前设置了set PYTHONUTF8=1,结果又报这个UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd2 in position 706: invalid continuation byte错误,挺迷惑的,于是又改回来set PYTHONUTF8=0
FAILED: obj/sandbox/win/acls.stamp
E:/CEF/depot_tools/bootstrap-2@3_8_10_chromium_26_bin/python3/bin/python3.exe ../../build/win/set_appcontainer_acls.py --stamp=obj/sandbox/win/acls.stamp --dir=.
Traceback (most recent call last):File "../../build/win/set_appcontainer_acls.py", line 35, in <module>main()File "../../build/win/set_appcontainer_acls.py", line 29, in maincommon.set_lpac_acls(os.path.abspath(args.dir))File "E:\CEF\chromium_git\chromium\src\testing\scripts\common.py", line 72, in set_lpac_aclsexisting_acls = subprocess.check_output(['icacls', acl_dir],File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\subprocess.py", line 415, in check_outputreturn run(*popenargs, stdout=PIPE, timeout=timeout, check=True,File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\subprocess.py", line 495, in runstdout, stderr = process.communicate(input, timeout=timeout)File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\subprocess.py", line 1015, in communicatestdout = self.stdout.read()File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python3\bin\lib\codecs.py", line 322, in decode(result, consumed) = self._buffer_decode(data, self.errors, final)
UnicodeDecodeError: 'utf-8' codec can't decode byte 0xd2 in position 706: invalid continuation byte
[2139/57096] ACTION //net/base/registry_controlled_domains...ry_controlled_domains(//build/toolchain/win:win_clang_x64)
ninja: build stopped: subcommand failed.

打包cef

这里为了能打包standard版本的cef二进制分发包,所以我又编译了一次debug版本的。然后在\chromium_git\chromium\src\cef\tools路径下执行

make_distrib.bat --ninja-build --no-docs --x64-build
  • –ninja-build:使用ninja构建
  • –no-docs:不创建文档
  • –x64-build:64位

不加--x64-build默认为x86版本

然后等待片刻就可以在chromium\src\cef\binary_distrib看到制作好的二进制分发包了

问题处理

  1. ERROR: Failed to find vcvars
ERROR: Failed to find vcvars
Traceback (most recent call last):File "E:\CEF\chromium_git\chromium\src\cef\tools\\make_distrib.py", line 949, in <module>os.path.join(dst_dir, 'cef_sandbox.lib'))File "E:\CEF\chromium_git\chromium\src\cef\tools\\make_distrib.py", line 404, in combine_libsrun(cmdline, os.path.join(cef_dir, 'tools'))File "E:\CEF\chromium_git\chromium\src\cef\tools\\make_distrib.py", line 442, in runargs, cwd=working_dir, env=os.environ, shell=(sys.platform == 'win32'))File "E:\CEF\depot_tools\bootstrap-2@3_8_10_chromium_26_bin\python\bin\lib\subprocess.py", line 190, in check_callraise CalledProcessError(retcode, cmd)

设置CEF_VCVARS环境变量

set CEF_VCVARS=D:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvars64.bat

之后就可正常执行了。

总结

晒个测试截图
在这里插入图片描述

在Windows上编译CEF源码,反而没有Linux上顺畅。

https://html5test.com/
https://zhuanlan.zhihu.com/p/133675543
记录一次项目中CEF版本的升级(二):CEF编译 - river12 - 博客园 (cnblogs.com)

https://www.moguf.com/post/wincefbuild

https://longxuan.ren/2021/07/24/CEF-Build-On-Windows/

https://www.magpcss.org/ceforum/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/85907.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

湘大 XTU OJ 1148 三角形 题解(非常详细):根据题意朴素模拟+观察样例分析需要计算几轮 具体到一般

一、链接 1148 三角形 二、题目 题目描述 给一个序列&#xff0c;按下面的方式进行三角形累加&#xff0c;求其和值。 比如序列为 1,2,3,4,5 1 2 3 4 53 5 7 98 12 1620 2848输入 有多组样例。每个样例的第一行是一个整数N(1≤N≤100),表示序列的大小&…

27.Netty源码之FastThreadLocal

highlight: arduino-light FastThreadLocal FastThreadLocal 的实现与 ThreadLocal 非常类似&#xff0c;Netty 为 FastThreadLocal 量身打造了 FastThreadLocalThread 和 InternalThreadLocalMap 两个重要的类。下面我们看下这两个类是如何实现的。 FastThreadLocalThread 是对…

0基础学习VR全景平台篇 第80篇:Insta360 影石如何直播推流

一、下载Insta360 Pro APP 1、手机进入Insta360官网Insta360 | Action Cameras | 360 Cameras | VR Cameras&#xff0c;页面往下滑动到Insta360 Pro2相机处&#xff0c;点击相机图片进入详情页。详情页继续下滑到到手机APP处&#xff0c;根据自己的手机系统选择对应的客户端进…

PhotoShop2023 Beta AI版安装教程

从 Photoshop 开始&#xff0c;惊艳随之而来​ 从社交媒体贴子到修饰相片&#xff0c;设计横幅到精美网站&#xff0c;日常影像编辑到重新创造 – 无论什么创作&#xff0c;Photoshop 都可以让它变得更好。​ Photoshop2023 Beta版本安装教程和软件下载 地址&#xff1a;点击…

dubbo之高可用

负载均衡 概述 负载均衡是指在集群中&#xff0c;将多个数据请求分散到不同的单元上执行&#xff0c;主要是为了提高系统的容错能力和对数据的处理能力。 Dubbo 负载均衡机制是决定一次服务调用使用哪个提供者的服务。 策略 在Dubbo中提供了7中负载均衡策略&#xff0c;默…

Vue生命周期函数(详解)

目录 生命周期图 生命周期函数 beforeCreate和created的区别 beforeCreate创建前应用场景 created创建后应用场景 beforeMount和mounted的区别 beforeMount挂载前应用场景 mounted挂载后应用场景 beforeUpdate和updated的区别 beforeUpdate更新前应用场景 updated更新后应用…

Linux:Shell编辑之文本处理器(awk)

目录 绪论 1、用法 1.1 格式选项 1.2 awk 常用内置变量 1.3 awk的打印功能 1.4 奇偶打印 1.5 awk运算 1.6 awk的内置函数&#xff1a;getline 1.7 文本过滤打印 1.8 awk条件判断打印 1.9 三元表达式&#xff0c;类似于java 1.10 awk的精确筛选 1.11 awk和tr比较改变…

RabbitMQ 79b5ad38df29400fa52ef0085a14b02f

RabbitMQ 一、什么是消息队列 消息队列可以看作是一个存放消息的容器&#xff0c;其中&#xff0c;生产者负责生产数据到消息队列中&#xff0c;而消费者负责消费数据。消息队列是分布式系统中重要的组件&#xff0c;目前使用较多的消息队列有ActiveMQ&#xff0c;RabbitMQ&am…

【雕爷学编程】Arduino动手做(202)---热释电效应、热释电元件与HC-SR505运动传感器模块

37款传感器与模块的提法&#xff0c;在网络上广泛流传&#xff0c;其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块&#xff0c;依照实践出真知&#xff08;一定要动手做&#xff09;的理念&#xff0c;以学习和交流为目的&#x…

谈谈Spring与字节码生成技术

Java程序员几乎都了解Spring。 它的IoC&#xff08;依赖反转&#xff09;和AOP&#xff08;面向切面编程&#xff09;功能非常强大、易用。而它背后的字节码生成技术&#xff08;在运行时&#xff0c;根据需要修改和生成Java字节码的技术&#xff09;就是一项重要的支撑技术。 …

PK Nounique CASCADE DROP INDEX keep index

Explicit Control Over Indexes when Creating, Disabling, or Dropping PK/Unique Constraints (Doc ID 139666.1)​编辑To Bottom PURPOSEIn Oracle 9i, the DBA has an explicit control over how indexes are affectedwhile creating, disabling, or dropping Primary Ke…

自动切换HTTP爬虫ip助力Python数据采集

在Python的爬虫世界里&#xff0c;你是否也被网站的IP封锁问题困扰过&#xff1f;别担心&#xff0c;我来教你一个终极方案&#xff0c;让你的爬虫自动切换爬虫ip&#xff0c;轻松应对各种封锁和限制&#xff01;快来跟我学&#xff0c;让你的Python爬虫如虎添翼&#xff01; 首…

SpringBoot 项目使用 Redis 对用户 IP 进行接口限流

一、思路 使用接口限流的主要目的在于提高系统的稳定性&#xff0c;防止接口被恶意打击&#xff08;短时间内大量请求&#xff09;。 比如要求某接口在1分钟内请求次数不超过1000次&#xff0c;那么应该如何设计代码呢&#xff1f; 下面讲两种思路&#xff0c;如果想看代码可…

【redis 3.2 集群】

目录 一、Redis主从复制 1.概念 2.作用 2.1 数据冗余 2.2 故障恢复 2.3 负载均衡 2.4 高可用 3.缺点 4.流程 4.1 第一步 4.2 第二步 4.3 第三步 4.4 第四步 5.搭建 5.1 主 5.2 从 6.验证 二、Reids哨兵模式 1.概念 2.作用 2.1 监控 2.2 自动故障转移 2.…

ArcGIS Pro基础:【按顺序编号】工具实现属性字段的编号自动赋值

本次介绍一个字段的自动排序编号赋值工具&#xff0c;基于arcgis 的字段计算器工具也可以实现类似功能&#xff0c;但是需要自己写一段代码实现&#xff0c; 相对而言不是很方便。 如下所示&#xff0c;该工具就是【编辑】下的【属性】下的【按顺序编号】工具。 其操作方法是…

redis基础

目录 前言 一、概述 1.NoSQL 2.Redis 二、安装 1.编译安装 2.RPM安装 三、目录结构 四、命令解析 五、redis登录更改 六、数据库操作 &#xff08;一&#xff09;、登录数据库 1.本地 2.远程登录 &#xff08;二&#xff09;、数据操作 1.数据库操作 2.数据操作 …

C++笔记之将定时器加入向量并设置定时器的ID为i

C笔记之将定时器加入向量并设置定时器的ID为i code review! 文章目录 C笔记之将定时器加入向量并设置定时器的ID为i关于代码中的void operator()() 运行 代码 #include <chrono> #include <iostream> #include <thread> #include <vector>// 定义定时…

京东秋招攻略,备考在线测评和网申笔试

京东秋招简介 伴随着社会竞争越来越激烈&#xff0c;人们投递简历的岗位也变得越来越多元&#xff0c;而无论人们的选择面变成何样&#xff0c;那些知名度较高的企业&#xff0c;永远都备受关注&#xff0c;只要其一发布招聘公告&#xff0c;总有人第一时间踊跃报名。而作为这…

linux自启动程序

嵌入式linux下有软件需要自启动&#xff0c;只需要在/etc/init.d/rcS末尾添加所要启动的程序即可&#xff0c;开机就会自动运行 vi /etc/init.d/rcS在文件末尾添加 例&#xff1a;

Zabbix6 对接飞书告警

文章目录 Zabbix对接飞书告警背景创建飞书群组Zabbix配置创建告警媒介类型创建动作用户关联飞书告警 Zabbix对接飞书告警 背景 运维 你看下他的进程是不是挂了&#xff0c;之前在9点28分有发消息的&#xff0c;这次没有发消息 哐哐哐的去看了一通&#xff0c;确实有个进程之前…