该帖子系列已在 ngatesystems.com 上建立索引。您还可以在那里找到超级有用的关键字搜索工具。
最后评论:24 年 11 月
一、简介
post 4.2 提出了预渲染网页的概念。这个想法是,如果一个页面从不改变(或者至少不经常改变),那么它也可能在项目的“构建”过程中被转换成 html。
这很好,但是,如果底层数据更改得太频繁,运行构建来使预渲染页面保持最新手动将会变得烦人。 自动化肯定是答案。
您可以通过多种方式解决这个问题,但我建议使用脚本来运行构建/部署序列,然后让 windows 调度程序自动运行它
2. powershell 构建/部署脚本
这是您可能会使用的 ps1 脚本:
$projectId = [myProjectId] $projectPath = [myProjectPath] # Define log file path $logPath = "$projectPathlog.txt" # Overwrite the log file with a timestamp at the beginning $timestamp = Get-Date -Format "yyyy-MM-dd HH:mm:ss" "Log started at $timestamp" | Out-File -FilePath $logPath -Force # Set the project ID gcloud config set project $projectId # Redirect output to log file try { cd $projectPath 2>&1 | Out-File -FilePath $logPath -Append npm run build | Out-File -FilePath $logPath -Append # Fetch all versions ordered by creation date, excluding the latest 10 $oldVersions = gcloud app versions list ` --sort-by="~version.createTime" ` --format="value(version.id)" | Select-Object -Skip 10 # Delete the old versions if there are any if ($oldVersions.Count -gt 0) { "Deleting old versions..."| Out-File -FilePath $logPath -Force $oldVersions | ForEach-Object { gcloud app versions delete $_ --quiet 2>&1 | Out-File -FilePath $logPath -Append } } else { "No old versions to delete. The limit of $MaxVersions is not exceeded." | Out-File -FilePath $logPath -Force } gcloud app deploy build/app.yaml --quiet 2>&1 | Out-File -FilePath $logPath -Append } catch { "An error occurred: $_" | Out-File -FilePath $logPath -Append }
登录后复制
在此脚本中,[myprojectid} 是您的 google 项目 id - 例如“svelte-dev-80286”
[myprojectpath] 是 vscode 项目的完整路径名 - 例如“c:usersmjoycdesktopgitprojectssvelte-dev”。输出 log.txt 文件最终位于 vscode 项目文件夹的根目录
脚本看起来比你想象的更复杂。原因如下:
因为您打算自动调度脚本,所以您需要维护一个日志文件,以便在出现错误时告诉您出了什么问题。仅此一点就增加了许多不可避免的“混乱”。但还有一个奇怪的“版本删除”部分。您需要这个,因为每次您运行“构建”时,google 都会在云存储中创建一个新版本。您可以创建的版本数量有默认上限。当我的系统在版本数达到 200 时出错时,我添加了此部分。
在上面的脚本中,我将维护的版本数量限制为 10 个(我现在正在为我的应用程序运行托管付费!)。
在 vscode 终端会话中测试脚本文件的最直接方法是选择其内容,将其粘贴到会话中并按回车键。但出于生产目的,您需要一些自动化。
3. 配置 windows 计划来运行 powershell 脚本
以下是注册 windows scheduler 任务以运行构建脚本的过程。
- 在 windows 搜索栏中输入“任务计划程序”并打开应用程序。
- 在“操作”菜单中,单击“创建基本任务”。
- 提供任务的名称和描述
- 在“触发器”选项卡上,选择要运行程序的时间间隔,例如“每日”、“每周”等。
- 指定任务的开始日期/时间和频率。
- 选择“启动程序”选项按钮。
- 现在,在“启动程序”窗口中: 在程序/脚本中:使用“浏览”帮助您输入windows powershell的路径,例如:c:windowssystem32windowspowershellv1.0powershell.exe 在参数中:输入脚本的完整路径。例如:[脚本的完整路径][我的脚本文件名].ps1 在“开始于”中:输入脚本所在的文件夹路径。例如“[脚本的完整路径]”
- 在下一个窗口中,选中“单击“完成”时打开此任务的属性对话框”复选框,然后单击“完成”按钮。
- 在属性对话框的常规选项卡中,确保选中“用户登录或未登录时运行”和“以最高权限运行”复选框。这可确保您以管理员权限运行脚本。
- 单击“确定”按钮,并使用您计算机的 microsoft 用户名和密码响应登录提示,确认您保存新计划程序任务的权利。
- 打开任务计划库,右键单击此处的任务条目并选择“运行”来测试新任务
我使用通过上述过程创建的 windows scheduler 任务来为预渲染的“ngatesystems.com”关键字搜索页面运行夜间构建。尽管现在很少添加新帖子,但我仍在对现有页面进行定期编辑。每晚运行的安排意味着搜索页面永远不会落后于实时数据超过一天。
以上就是NgSysVAutomated Svelte Pre-render Builds的详细内容,更多请关注抖狐科技其它相关文章!
-
小米手机怎么调节屏幕亮度_手机屏幕亮度设置流程一览
小米手机,作为当前智能手机市场中的佼佼者,凭借其出色的性能、创新的科技以及人性化的设计,赢得了众多消费者的青睐。有很多的小伙伴想要了解小米手机如何调节屏幕亮度,小编这里整理了些相关资料,有需要的小伙伴...
-
Java函数式编程中递归的边界条件如何处理?
递归边界条件在 java 函数式编程中至关重要,以防止无限递归。边界条件提供停止点,通常基于函数输入或状态。例如,阶乘函数的边界条件是 n == 0,当 n 为 0 时递归停止。常见陷阱包括忘记设置边...
-
如何用正则表达式实现小说分段排版?
正则表达式实现小说分段排版的利器 在小说排版中,控制每行显示字符数量并合理分段是常见需求。其中,正则表达式凭借其强大的文本处理能力成为这一任务的理想解决方案。 要实现每行限定40个字符,自动分段,可以...
-
2024年09月17日OK币价格_OK币今日最新价格
(24小时OK币价格走势) okb 最新市场分析 截至撰稿时,OKB 的价格为 38.39 美元,24 小时交易量为 186 万美元。过去 24 小时内,价格上涨了 1.00%。 价格变动的因素 近期...
-
炉石传说卡包怎么获得,炉石传说怎么合金卡
游戏介绍:《炉石传说:魔兽英雄传》是一款由雪娱乐开发的集换式卡牌游戏。大陆地区的独家运营由网易公司代理。2014年3月13日全球同步正式运营。 游戏背景设定于雪的魔兽系列,共九位魔兽中的角色作为九种不...