- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我和我的 DBA 正在努力研究如何有效地使用 Microsoft 的数据库项目和它们生成的 Dacpacs 来简化我们的生产部署系统。
理想情况下,我将能够构建和/或发布 .sqlproj
,生成一个 .dacpac
文件,然后可以将其上传到生产服务器并使用将数据库从任何版本升级到最新版本。这类似于我们进行网站部署的方式,我发布到一个包,然后将该包上传到服务器并导入到 IIS。
但是,我们无法弄清楚如何让它发挥作用。 DBA 已经创建了数据库并将其添加到我们的可用性组中。每次我们尝试应用 Dacpac 时,它都会尝试调整由于 AG 而无法调整的设置。
我无法创建 .dacpac
文件,该文件不会尝试对数据库施加设置。我找到的最接近的选项会在发布时将它们排除在外,但据我所知,您不能发布到无法访问的数据库,只有 DBA 才能访问生产服务器。
我真的可以这样使用 dacpacs 吗?
最佳答案
这有两个部分,首先,您如何停止部署您不想部署的设置 - 您能否举例说明其中一个不适用的设置?
对于您无法访问 SQL Server 的第二部分,有几种不同的方法可以处理此问题:
选项 1:“使用离线副本生成部署脚本”
您需要将 dacpac 与某些东西进行比较,如果您没有 TDS 连接(默认实例默认端口 tcp:1433),那么您可以通过以下方式使用与生产相匹配的数据库版本:
日志传送副本是最简单的,如果是开发服务器,您通常可以拥有服务器权限来为您提供访问权限,或者您可以在数据库级别而不是生产服务器级别创建正确的权限。
如果数据是敏感的,那么日志传送的副本可能不合适,因此您可以尝试使开发和生产数据库保持同步,但这很困难,并且要求 DBA 接受“良好培训”,不要运行任何不符合要求的东西' 也首先针对 db 数据库运行。
一旦您有权访问与生产数据库具有完全相同架构的数据库,您就可以使用 sqlpackage.exe/action:script 生成部署脚本,事实上,因为它不是生产数据库,您可以生成脚本作为 CI 流程的一部分 :).
选项 2:“让 DBA 生成部署脚本”
这是为了让 DBA 将 dacpac 复制到生产服务器,并使用位于“Program Files (x86)\Microsoft Sql Server\Version\DAC\bin”文件夹中的 sqlpackage.exe 将 dacpac 与数据库并生成一个他可以在部署前查看的脚本。
选项 3:“让 DBA 生成部署脚本”
这与选项 2 类似,但他没有生成在 SSMS 中部署的脚本,而是使用 sqlpackage.exe/Action:Publish 直接部署更改。
选项 4:“获取对数据库的只读访问权限”
这实际上是我的首选,因为它意味着您始终根据保证的生产状态(因为它是生产状态)构建脚本。在您的情况下,您需要在您的机器或理想情况下您的构建机器与 SQL Server 之间获取 tcp 端口,然后您将需要这些权限:
正如我所说,选项 4 始终是我的首选,但我知道这并不总是可行的。
选项 2 + 3 令人担忧,因为您将运行尚未在任何地方测试过的脚本,使用选项 4 和 1 您可以生成脚本,然后部署到测试/QA 数据库,只要它们自己有与生产相同的架构。脚本还可以通过代码审查过程。
如果您选择选项 2/3,那么我将创建一个驱动 sqlpackage.exe 的批处理文件或 powershell 脚本,如果它们从没有 sqlpackage.exe 的不同服务器部署,那么您可以将 DAC 文件夹复制到那个机器并从中运行 sqlpackage,您不必实际安装它(您可能还需要从“Program Files (x86)\Microsoft Sql Server\Version\SDK\”复制 Microsoft.SqlServer.TransactSql.ScriptDom.dll程序集”文件夹。
希望这对您有所帮助,如果您还有其他问题,请随时在这里发帖或私信我 :)
编辑
关于sql-server - 将 Dacpacs 部署到锁定生产中的可用性组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32705393/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!