分类 顶到头了 下的文章

1、查看当前用户的 crontab 文件:

crontab -l

2、编辑当前用户的 crontab 文件:

crontab -e

3、删除当前用户的 crontab 文件:

crontab -r

4、列出系统上所有用户的 crontab 任务:

sudo crontab -l

5、重启 cron 服务:

sudo service cron restart  或者  sudo systemctl restart cron

5、查看 cron 服务状态:

sudo service cron status  或者  sudo systemctl status cron

6、环境变量:
默认情况下,cron 任务不会加载用户的环境变量。如果需要环境变量,可以将其添加到 crontab 文件中,或者使用 env 命令将它们传递给 cron。

在编辑 crontab 文件时,每一行都代表一个计划任务,格式如下

*     *     *   *    *        command to be executed
-     -     -   -    -
|     |     |   |    |
|     |     |   |    +----- day of the week (0 - 6) (Sunday=0)
|     |     |   +------- month (1 - 12)
|     |     +--------- day of the month (1 - 31)
|     +----------- hour (0 - 23)
+------------- min (0 - 59)

例如,下面的 crontab 条目表示每天凌晨 1 点执行 /path/to/script.sh 脚本:

0 1 * * * /path/to/script.sh

使用 crontab 时,请确保正确设置时间,并且脚本有执行权限。

示例:

json_encode($queryParams, JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES)//多个常量用|分隔

常量注释:

JSON_ERROR_NONE (int)
没有错误发生。
JSON_ERROR_DEPTH (int)
到达了最大堆栈深度。
JSON_ERROR_STATE_MISMATCH (int)
出现了下溢(underflow)或者模式不匹配。
JSON_ERROR_CTRL_CHAR (int)
控制字符错误,可能是编码不对。
JSON_ERROR_SYNTAX (int)
语法错误。
JSON_ERROR_UTF8 (int)
异常的 UTF-8 字符,也许是因为不正确的编码。
JSON_ERROR_RECURSION (int)
传递给 json_encode() 函数的对象或数组包含了递归引用,导致无法被编码。如果打开了 JSON_PARTIAL_OUTPUT_ON_ERROR 选项,则牵涉到递归引用的数据会转换成 null 后返回。
JSON_ERROR_INF_OR_NAN (int)
传递给 json_encode() 函数的参数中包含了 NAN 或 INF,导致编码出错。如果打开了 JSON_PARTIAL_OUTPUT_ON_ERROR 选项,则牵涉到对应不可编码的数字,会转换成数字 0 后返回。
JSON_ERROR_UNSUPPORTED_TYPE (int)
传递了不支持的数据类型给 json_encode() 函数,比如 resource。如果打开了 JSON_PARTIAL_OUTPUT_ON_ERROR 选项,则对于不支持的数据类型,会转换成 null 后返回。
JSON_ERROR_INVALID_PROPERTY_NAME (int)
A key starting with \u0000 character was in the string passed to json_decode() when decoding a JSON object into a PHP object.
JSON_ERROR_UTF16 (int)
Single unpaired UTF-16 surrogate in unicode escape contained in the JSON string passed to json_encode().
下面的常量可以和 json_decode() 的 form 选项结合使用。

JSON_BIGINT_AS_STRING (int)
将大数字编码成原始字符原来的值。
JSON_OBJECT_AS_ARRAY (int)
将 JSON 对象作为数组解码。当调用 json_decode() 且第二个参数为 true 时此选项会自动添加。
下面的常量可以和 json_encode() 的 form 选项结合使用。

JSON_HEX_TAG (int)
所有的 < 和 > 转换成 \u003C 和 \u003E。
JSON_HEX_AMP (int)
所有的 & 转换成 \u0026。
JSON_HEX_APOS (int)
所有的 ' 转换成 \u0027。
JSON_HEX_QUOT (int)
所有的 " 转换成 \u0022。
JSON_FORCE_OBJECT (int)
使一个非关联数组输出一个类(Object)而非数组。 在数组为空而接受者需要一个类(Object)的时候尤其有用。
JSON_NUMERIC_CHECK (int)
将所有数字字符串编码成数字(numbers)。
JSON_PRETTY_PRINT (int)
用空白字符格式化返回的数据。
JSON_UNESCAPED_SLASHES (int)
不要编码 /。
JSON_UNESCAPED_UNICODE (int)
以字面编码多字节 Unicode 字符(默认是编码成 \uXXXX)。
JSON_PARTIAL_OUTPUT_ON_ERROR (int)
用不可编码的值来代替失败。
JSON_PRESERVE_ZERO_FRACTION (int)
确保 float 值始终编码为为 float 值。
JSON_UNESCAPED_LINE_TERMINATORS (int)
The line terminators are kept unescaped when JSON_UNESCAPED_UNICODE is supplied. It uses the same behaviour as it was before PHP 7.1 without this constant. Available since PHP 7.1.0.
下面的常量可以和 json_decode() 及 json_encode() 的 form 选项结合使用。

JSON_INVALID_UTF8_IGNORE (int)
忽略无效的 UTF-8 字符。自 PHP 7.2.0 起生效。
JSON_INVALID_UTF8_SUBSTITUTE (int)
将无效 UTF-8 字符转换为 \0xfffd(Unicode 字符“虚缺号”)。自 PHP 7.2.0 起生效。
JSON_THROW_ON_ERROR (int)
如果发生错误则会抛出 JsonException,而不是通过 json_last_error() 和 json_last_error_msg() 检索设置到全局的错误状态。JSON_PARTIAL_OUTPUT_ON_ERROR 优先于 JSON_THROW_ON_ERROR。自 PHP 7.3.0 起生效。
JSON_ERROR_NON_BACKED_ENUM (int)
传递给 json_encode() 的值包含了无法序列化的非支持的枚举。 自 PHP 8.1.0 起生效。

注:内容来源:https://www.php.net/manual/zh/json.constants.php

问题:今天,线上接口突然报The HTTP status code "0" is not valid异常,第一次见http状态码0
排查:
1、调用接口,打断点排查,因为接口响应时间有点长,首先排查是不是有慢查询,通过阿里云后台并没有发下有慢查询记录
2、排查调用接口,发现有一个第三方接口,直接报错400
3、加try,catch ,如果第三方接口有异常在log记录异常信息
总结:如果遇到这个问题,不妨先打断点,找到抛出异常的代码,进行优化,网上有的说法,看不明白,也解决不了问题

首页,创建服务,生成API_KEY
其次,请求向量api,生成向量
示例:

import os
from openai import AzureOpenAI

client = AzureOpenAI(
  api_key = os.getenv("AZURE_OPENAI_API_KEY"),  //API_KEY
  api_version = "2024-02-01",  //版本号,使用默认值即可
  azure_endpoint =os.getenv("AZURE_OPENAI_ENDPOINT")  //申请的域名地址
)

response = client.embeddings.create(
    input = "Your text string goes here", //生成向量内容,这里会按照内容生成指定向量值,后期用于匹配
    model= "text-embedding-ada-002"
)

print(response.model_dump_json(indent=2))

注:向量生成完后需要存储到向量库,这里使用的是milvus,milvus:vector长度需要与向量长度一致,比如都为256
官方文档:
AzureOpenAI:https://learn.microsoft.com/zh-cn/azure/ai-services/openai/how-to/embeddings?tabs=python-new
milvus:https://milvus.io/docs