通过


在 Linux 上创建和运行SQL Server 代理作业

适用于:SQL Server 在 Linux 上

SQL Server作业用于在SQL Server数据库中定期执行相同的命令序列。 本教程提供了如何使用 Transact-SQL 和 SQL Server Management Studio (SSMS) 在 Linux 上创建SQL Server 代理作业的示例。

  • 在 Linux 上安装SQL Server 代理
  • 创建新作业以执行每日数据库备份
  • 计划并运行作业
  • 在 SSMS 中执行相同的步骤(可选)

有关 Linux 上的SQL Server 代理的已知问题,请参阅 Linux 上的 SQL Server:已知问题

先决条件

若要完成本教程,需满足以下先决条件:

以下先决条件是可选的:

启用SQL Server 代理

若要在 Linux 上使用SQL Server 代理,必须先在已安装SQL Server的计算机上启用SQL Server 代理。

  1. 若要启用SQL Server 代理,请运行以下命令。

    sudo /opt/mssql/bin/mssql-conf set sqlagent.enabled true
    
  2. 使用以下命令重启SQL Server:

    sudo systemctl restart mssql-server
    

注意

从 SQL Server 2017 (14.x) CU 4 开始,SQL Server 代理包含在 mssql-server 包中,默认禁用。 有关 CU 4 之前设置的代理,请参阅 Linux 上的 Install SQL Server 代理

创建示例数据库

使用以下步骤创建名为 SampleDB 的示例数据库。 此数据库用于每日备份作业。

  1. 在 Linux 计算机上,打开 bash 终端会话。

  2. 使用 sqlcmd 运行 Transact-SQL CREATE DATABASE 命令。

    /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -Q 'CREATE DATABASE SampleDB'
    
  3. 通过列出服务器上的数据库来验证是否已创建该数据库。

    /opt/mssql-tools/bin/sqlcmd -S localhost -U sa -Q 'SELECT name FROM sys.databases'
    

使用 Transact-SQL 创建作业

以下步骤使用 Transact-SQL 命令在 Linux 上创建SQL Server 代理作业。 该作业运行示例数据库 SampleDB 的每日备份。

提示

可以使用任何 T-SQL 客户端运行这些命令。 例如,在 Linux 上,你可以安装 sqlcmd 和 bcp SQL Server 命令行工具,或者使用 用于 Visual Studio Code 的 SQL Server 扩展。 在远程Windows Server中,还可以在SQL Server Management Studio(SSMS)中运行查询,或使用 UI 界面进行作业管理,下一部分将介绍。

  1. 使用sp_add_job创建名为Daily SampleDB Backup的作业。

    -- Adds a new job executed by the SQLServerAgent service
    -- called 'Daily SampleDB Backup'
    USE msdb;
    GO
    
    EXECUTE dbo.sp_add_job @job_name = N'Daily SampleDB Backup';
    GO
    
  2. 调用 sp_add_jobstep 来创建 SampleDB 数据库的备份。

    EXECUTE sp_add_jobstep
        @job_name = N'Daily SampleDB Backup',
        @step_name = N'Backup database',
        @subsystem = N'TSQL',
        @command = N'BACKUP DATABASE SampleDB TO DISK = \
                         N''/var/opt/mssql/data/SampleDB.bak'' WITH NOFORMAT, NOINIT, \
                         NAME = ''SampleDB-full'', SKIP, NOREWIND, NOUNLOAD, STATS = 10', @retry_attempts = 5, @retry_interval = 5;
    GO
    
  3. 然后使用 sp_add_schedule为作业创建每日计划。

    -- Creates a schedule called 'Daily'
    EXECUTE dbo.sp_add_schedule
        @schedule_name = N'Daily SampleDB',
        @freq_type = 4,
        @freq_interval = 1,
        @active_start_time = 233000;
    
    USE msdb;
    GO
    
  4. 使用 sp_attach_schedule将作业计划附加到作业。

    -- Sets the 'Daily' schedule to the 'Daily SampleDB Backup' Job
    EXECUTE sp_attach_schedule
        @job_name = N'Daily SampleDB Backup',
        @schedule_name = N'Daily SampleDB';
    GO
    
  5. 使用 sp_add_jobserver 将作业分配给目标服务器。 此示例中的目标是本地服务器。

    EXECUTE dbo.sp_add_jobserver
        @job_name = N'Daily SampleDB Backup',
        @server_name = N'(local)';
    GO
    
  6. 使用 sp_start_job启动作业。

    EXECUTE dbo.sp_start_job N' Daily SampleDB Backup';
    GO
    

使用 SSMS 创建作业

还可以使用 Windows 上的 SQL Server Management Studio (SSMS) 远程创建和管理作业。

  1. 在 Windows 上启动 SSMS 并连接到 Linux SQL Server 实例。 有关详细信息,请参阅 使用Windows SQL Server Management Studio来管理 Linux 上的 SQL Server

  2. 验证是否已创建名为 SampleDB 的示例数据库。

    创建 SampleDB 数据库的屏幕截图。

  3. 验证 SQL 代理是否已在 Linux 上Install SQL Server 代理并正确配置。 在对象资源管理器中查找SQL Server 代理旁边的加号。 如果未启用SQL Server 代理,请尝试在 Linux 上重启 mssql-server 服务。

    Screenshot 演示如何验证是否已安装SQL Server 代理.

  4. 创建新作业。

    显示如何创建新作业的屏幕截图。

  5. 指定作业名称并创建作业步骤。

    显示如何创建作业步骤的屏幕截图。

  6. 指定要使用的子系统以及作业步骤应执行的操作。

    SSMS 中“新建作业”对话框的屏幕截图,其中显示了“步骤”页,其中突出显示了“新建”按钮以创建作业步骤。

    “新建作业步骤”对话框的屏幕截图,其中显示了 SampleDB 的 T-SQL BACKUP DATABASE 命令,其中突出显示了“确定”按钮。

  7. 创建新的作业计划。

    “新建作业”对话框的屏幕截图,其中突出显示了“计划”选项,并突出显示了“新建”选项。

    “新建作业”对话框的屏幕截图,其中已调出“确定”选项。

  8. 开始工作。

    截图显示如何启动 SQL Server 代理 作业。

下一步

在本教程中,你了解了如何执行以下操作:

  • 在 Linux 上安装SQL Server 代理
  • 使用Transact-SQL和系统存储过程创建作业
  • 创建用于执行每日数据库备份的作业
  • 使用 SSMS UI 创建和管理作业

接下来,探索用于创建和管理作业的其他功能: