{"id":339880,"date":"2022-10-18T03:00:12","date_gmt":"2022-10-18T03:00:12","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=339880"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=339880","title":{"rendered":"<span>\u0418\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 copy-on-write \u043d\u0430 \u0441\u0442\u0435\u043d\u0434\u0430\u0445 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438 \u0438 \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0441 \u0431\u0430\u0437\u0430\u043c\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 SQL Server<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-1\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/webt\/7m\/mr\/sv\/7mmrsvigkrcas7ajrcjgbbgrjzk.jpeg\" alt=\"CoW\" data-src=\"https:\/\/habrastorage.org\/webt\/7m\/mr\/sv\/7mmrsvigkrcas7ajrcjgbbgrjzk.jpeg\" data-blurred=\"true\"\/><\/p>\n<p>  <\/p>\n<p>\u0412 \u043c\u0438\u0440\u0435 \u043a\u0440\u043e\u0432\u0430\u0432\u043e\u0433\u043e \u044d\u043d\u0442\u0435\u0440\u043f\u0440\u0430\u0439\u0437\u0443 \u0435\u0441\u0442\u044c \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432-\u043c\u0430\u043c\u043e\u043d\u0442\u043e\u0432. \u041e\u043d\u0438 \u0431\u043e\u043b\u044c\u0448\u0438\u0435, \u0443 \u043d\u0438\u0445 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 SQL Server, \u0432 \u044d\u0442\u0438\u0445 \u0431\u0430\u0437\u0430\u0445 \u0442\u044b\u0441\u044f\u0447\u0438 \u0438 \u0434\u0435\u0441\u0442\u044f\u043a\u0438 \u0442\u044b\u0441\u044f\u0447 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432, \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u044b \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430 T-SQL, \u043e\u0433\u0440\u043e\u043c\u043d\u0430\u044f \u0432\u0430\u0440\u0438\u0430\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0445, \u0432\u0441\u0451 \u0445\u0440\u0443\u043f\u043a\u043e\u0435, \u043d\u0435\u0438\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u043e\u0435, \u043d\u0435\u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u0438 \u0444\u0438\u0433\u043e\u0432\u043e \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435. \u041a\u043e\u0440\u043e\u0447\u0435, \u043a\u0430\u043a \u043f\u0438\u0441\u0430\u043b Roy Osherove \u0432 \u0441\u0432\u043e\u0435\u0439 The art of unit-testing:<\/p>\n<p>  <\/p>\n<blockquote><p>Finally, as a friend once said, a good bottle of vodka never hurts when dealing with legacy code.<\/p><\/blockquote>\n<p>\u0412 \u0432\u043e\u043b\u044c\u043d\u043e\u043c \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0435 &#171;\u0414\u0430 \u0442\u0430\u043c \u0431\u0435\u0437 \u043f\u043e\u043b\u043b\u0438\u0442\u0440\u044b \u043d\u0435 \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u0448\u044c\u0441\u044f!&#187;<\/p>\n<p>  <\/p>\n<p>\u0418 \u0432\u043e\u0442 \u0443 \u044d\u0442\u0438\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0435\u0441\u0442\u044c \u0431\u0435\u0434\u0430 \u2014 \u0431\u043e\u043b\u044c\u0448\u0438\u0435 \u043a\u043e\u043d\u0442\u0443\u0440\u044b \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0438 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438, \u0447\u0430\u0441\u0442\u043e \u0442\u0430\u043a \u0438\u043b\u0438 \u0438\u043d\u0430\u0447\u0435 \u043c\u043e\u0434\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0438 \u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u043d\u044b\u0435 \u043a\u043e\u043f\u0438\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0443\u0440\u0430. \u0414\u0430-\u0434\u0430-\u0434\u0430, \u0442\u0443\u0442 \u0441\u0440\u0430\u0437\u0443 \u043f\u043e\u043d\u0430\u043b\u0435\u0442\u044f\u0442 \u0443\u043c\u043d\u044b\u0435 \u0434\u0430 \u0432 \u0431\u0435\u043b\u043e\u0439 \u043e\u0434\u0435\u0436\u0434\u0435 \u0438 \u043d\u0430\u0447\u043d\u0443\u0442 \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u043d\u0430\u0434\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0435 \u043d\u0430\u0431\u043e\u0440\u044b \u0434\u0430\u043d\u043d\u044b\u0445 (\u0430 \u043a\u0442\u043e \u0441\u043f\u043e\u0440\u0438\u0442?), \u0447\u0442\u043e \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u043a\u043e\u043d\u0442\u0443\u0440 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0438\u043c (\u0430 \u043a\u0442\u043e \u0441\u043f\u043e\u0440\u0438\u0442?), \u0447\u0442\u043e \u043a\u043e\u0434 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u043c\u044b\u043c \u043c\u0435\u0436\u0434\u0443 \u0421\u0423\u0411\u0414 (\u0441\u043f\u0430\u0441\u0438\u0431\u043e, \u041a\u044d\u043f!), \u0447\u0442\u043e \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u0431\u044b \u043b\u0443\u0447\u0448\u0435, \u0435\u0441\u043b\u0438 \u0431\u044b \u043f\u0440\u043e\u0435\u043a\u0442 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043b\u0438 N \u043b\u0435\u0442 \u043d\u0430\u0437\u0430\u0434 (\u0445\u0430-\u0445\u0430) \u0438 \u043f\u0440\u043e\u0447\u0438\u0435 &#171;\u0441\u0442\u0430\u043d\u044c\u0442\u0435 \u0451\u0436\u0438\u043a\u0430\u043c\u0438&#187; \u0438 &#171;\u043f\u0443\u0441\u0442\u044c \u0435\u0434\u044f\u0442 \u043f\u0438\u0440\u043e\u0436\u043d\u044b\u0435&#187;. \u041d\u0435\u0442, \u0434\u043e\u0440\u043e\u0433\u0438\u0435 \u043c\u043e\u0438. \u041f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u044c\u0442\u0435, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0411\u0414 SQL Server \u0441 25\u041a \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 (\u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u0425\u041f) \u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430\u043c\u0438 \u0441\u0442\u0440\u043e\u043a \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u0438 \u0447\u0430\u0441\u0442\u044c \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0441\u043e\u0437\u0434\u0430\u043d\u0430 \u0441 <code>SET ANSI NULLS ON<\/code>, \u0430 \u0447\u0430\u0441\u0442\u044c \u0441 <code>SET ANSI NULLS OFF<\/code>. \u0418 \u0442\u043e\u0447\u043d\u043e \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e, \u0447\u0442\u043e \u0432 \u0447\u0430\u0441\u0442\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u044d\u0442\u0430 \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f. \u0418 \u0411\u0414 \u043d\u0430 \u0434\u0435\u0441\u0442\u044f\u043a\u0438 \u0422\u0438\u0411. \u0418 \u043e\u0434\u043d\u043e\u0434\u043d\u0435\u0432\u043d\u044b\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u0441\u0442\u043e\u0438\u0442 \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c \u043a\u0432\u0430\u0440\u0442\u0438\u0440\u044b \u0432\u0441\u0435\u0445 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 20 \u043b\u0435\u0442 \u0442\u0440\u043e\u0433\u0430\u043b\u0438 \u044d\u0442\u043e\u0442 \u043a\u043e\u0434 (\u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u044b\u0445, \u043a\u0441\u0442\u0430\u0442\u0438, \u0441\u0435\u0439\u0447\u0430\u0441 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e 7 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0445 \u0441\u0430\u043c\u0443\u0440\u0430\u0435\u0432). \u041e\u0434\u043d\u043e \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u043d\u0435 \u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u0441 SQL Server 2008 R2 \u043d\u0430 \u0447\u0442\u043e-\u0442\u043e \u0431\u043e\u043b\u0435\u0435 \u0441\u0432\u0435\u0436\u0435\u0435 \u043f\u0430\u0440\u0443 \u043b\u0435\u0442.<\/p>\n<p><a name=\"habracut\"><\/a>  <\/p>\n<p>\u041d\u0435 \u043d\u0430\u0434\u043e \u0434\u0443\u043c\u0430\u0442\u044c, \u0447\u0442\u043e \u043d\u0430 \u0442\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u0430\u0445 \u0440\u0430\u0431\u043e\u0442\u0430\u044e\u0442 \u0442\u0443\u043f\u044b\u0435 \u043b\u044e\u0434\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043d\u0435 \u0445\u043e\u0442\u044f\u0442 \u0440\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0438 \u0431\u044b\u0441\u0442\u0440\u043e. \u0425\u043e\u0442\u044f\u0442. \u041d\u043e \u0435\u0441\u0442\u044c \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b, \u043e\u0434\u043d\u043e\u0439 \u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0440\u0430\u0437\u043c\u0435\u0440, \u043d\u0435\u0442 <strong>\u0420\u0410\u0417\u041c\u0415\u0420<\/strong> \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0445 \u0441\u0440\u0435\u0434. \u041f\u043e\u043b\u043d\u043e\u0446\u0435\u043d\u043d\u044b\u0439 \u043f\u0440\u043e\u0433\u043e\u043d \u0441\u0430\u043c\u044b\u0445 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u044b\u0445 \u0442\u0435\u0441\u0442\u043e\u0432 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0447\u0430\u0441\u043e\u0432. \u0420\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0435\u0441\u043a\u0430\u044f \u0441\u0440\u0435\u0434\u0430 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u0441\u043e\u0442\u043d\u0438 \u0413\u0438\u0411 (\u0438 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u0438\u043a\u0438 \u043d\u0435 \u0434\u0430\u044e\u0442 \u0435\u0451 \u0442\u0430\u0449\u0438\u0442\u044c \u043d\u0430 \u043c\u0430\u0448\u0438\u043d\u0443 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432!), \u0430 \u0442\u0435\u0441\u0442\u043e\u0432\u0430\u044f \u2014 \u0431\u043e\u043b\u044c\u0448\u0435. \u0412\u0441\u0451 \u0447\u0442\u043e \u043c\u043e\u0433\u043b\u0438 \u0440\u0430\u0437\u0443\u043c\u043d\u043e\u0433\u043e \u0441 \u043d\u0435\u0439 \u0434\u043b\u044f \u043e\u0431\u043b\u0435\u0433\u0447\u0435\u043d\u0438\u044f \u0443\u0436\u0435 \u0441\u0434\u0435\u043b\u0430\u043b\u0438 (\u0431\u043b\u043e\u0431\u044b \u0432\u044b\u0447\u0438\u0449\u0435\u043d\u044b, \u0434\u0430\u043d\u043d\u044b\u0435 \u0443\u0440\u0435\u0437\u0430\u043d\u044b, \u0441\u0436\u0430\u0442\u0438\u0435 \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u0432\u043a\u043b\u044e\u0447\u0435\u043d\u043e, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 database snapshots \u0438 \u0442.\u0434.). \u0415\u0441\u043b\u0438 \u0445\u043e\u0442\u0438\u043c, \u0447\u0442\u043e\u0431\u044b \u0442\u0435\u0441\u0442\u044b \u043d\u0435 &#171;\u043c\u043e\u0440\u0433\u0430\u043b\u0438&#187;, \u0442\u043e, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u0441\u0440\u0435\u0434\u0430 \u0434\u043e\u043b\u0436\u043d\u0430 \u0431\u044b\u0442\u044c \u0432 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u043c \u0438 \u043a\u043e\u043d\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043d\u043e\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u2014 \u0442\u043e \u0435\u0441\u0442\u044c \u0441\u0432\u0435\u0436\u0435\u043f\u043e\u0434\u043d\u044f\u0442\u0430\u044f. \u0425\u043e\u0442\u0438\u043c \u0447\u0430\u0449\u0435 \u0434\u0435\u043b\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u044b, \u0445\u043e\u0442\u0438\u043c \u0431\u043e\u043b\u044c\u0448\u0435 \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u0442\u0430\u043a \u0434\u0430\u043b\u0435\u0435\u2026 \u041d\u043e \u2014 \u0420\u0410\u0417\u041c\u0415\u0420. \u0414\u0430, \u043a\u0441\u0442\u0430\u0442\u0438, \u043c\u043e\u0434\u043d\u043e\u043c\u0443 \u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440\u0443, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u0440\u0438\u0448\u0451\u043b \u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u0442: &#171;\u0410 \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u043f\u0435\u0440\u0435\u0441\u0430\u0434\u0438\u043c \u0432 \u043e\u0431\u043b\u0430\u043a\u043e&#187;, \u2014 \u0435\u043c\u0443 \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u043a\u0430\u0437\u0430\u043b\u0438, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0431\u0443\u0434\u0435\u0442 \u0441\u0442\u043e\u0438\u0442\u044c \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u0435 \u0441\u043e\u0442\u0435\u043d \u0422\u0438\u0411 \u0438 \u0438\u0445 \u0437\u0430\u043b\u0438\u0432\u043a\u0430 \u0432 \u043e\u0431\u043b\u0430\u043a\u0435 (\u0438 \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0440\u0435\u043c\u0435\u043d\u0438 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u043a\u043e\u043d\u0442\u0443\u0440). \u0411\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u043b\u0441\u044f. \u041d\u0430\u0432\u0435\u0440\u043d\u043e\u0435 \u0434\u0435\u043d\u0435\u0433 \u0438\u0449\u0435\u0442.<\/p>\n<p>  <\/p>\n<p>\u0422\u0430\u043a \u0447\u0442\u043e \u0436\u0435 \u0434\u0435\u043b\u0430\u0442\u044c? \u0417\u0430\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c\u0441\u044f \u0432 \u043f\u0440\u043e\u0441\u0442\u044b\u043d\u044e \u0438 \u043f\u043e\u043b\u0437\u0451\u043c \u043a \u043a\u043b\u0430\u0434\u0431\u0438\u0449\u0443? \u041d\u0415\u0422. \u041d\u0435 \u0442\u0430\u043a\u043e\u0432 \u043f\u0443\u0442\u044c \u0441\u0430\u043c\u0443\u0440\u0430\u044f. \u0410\u0431\u0437\u0430\u0446\u0435\u043c \u0432\u044b\u0448\u0435, \u044f \u0443\u043f\u043e\u043c\u0438\u043d\u0430\u043b \u0441\u043d\u0438\u043c\u043a\u0438 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 (database snapshots), \u044d\u0442\u043e \u0442\u0430\u043a\u0430\u044f \u0441\u0442\u0440\u0430\u043d\u043d\u0430\u044f \u043d\u0435\u0434\u043e\u0444\u0438\u0447\u0430 SQL Server (\u0443\u0436\u0435 \u043d\u0435 \u043f\u043e\u043c\u043d\u044e, \u0432 2005 \u0438\u043b\u0438 \u0432 2008 \u043e\u043d\u0430 \u043f\u043e\u044f\u0432\u0438\u043b\u0430\u0441\u044c). \u0414\u043e\u0441\u0442\u0443\u043f\u043d\u0430 \u0434\u043e \u0432\u0435\u0440\u0441\u0438\u0438 2016 \u0431\u044b\u043b\u0430 \u0442\u043e\u043b\u044c\u043a\u043e \u0432 Enterprise \u0438 Develop \u0440\u0435\u0434\u0430\u043a\u0446\u0438\u0438 (\u0430 \u043f\u043e\u0442\u043e\u043c \u0441 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f\u043c\u0438). \u0412 \u043e\u0431\u0449\u0435\u043c, \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439 NTFS, SQL Server \u0443\u043c\u0435\u0435\u0442 \u0434\u0435\u043b\u0430\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u0443\u044e \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0447\u0442\u0435\u043d\u0438\u044f &#171;\u043a\u043e\u043f\u0438\u044e&#187; \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445. \u041d\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0432 \u043c\u043e\u043c\u0435\u043d\u0442 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u043d\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442, \u0432\u043c\u0435\u0441\u0442\u043e \u044d\u0442\u043e\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f &#171;\u0440\u0430\u0437\u0440\u0435\u0436\u0435\u043d\u043d\u044b\u0439&#187; \u0444\u0430\u0439\u043b \u0438 \u043f\u043e\u0442\u043e\u043c \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446 \u043f\u0440\u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 \u043e\u0441\u043d\u043e\u0432\u043d\u0443\u044e \u0411\u0414 (Copy on write \u2014 CoW \u2014 <em>\u0432\u043e\u0442 \u043f\u043e\u0447\u0435\u043c\u0443 \u043d\u0430 \u043a\u0430\u0440\u0442\u0438\u043d\u043a\u0435 \u043a\u043e\u0440\u043e\u0432\u0430<\/em>). \u041f\u043e\u0447\u0435\u043c\u0443 &#171;\u043d\u0435\u0434\u043e\u0444\u0438\u0447\u0430&#187;? \u041d\u0443 \u043f\u0440\u043e\u0441\u0442\u043e \u0441 \u044d\u0442\u0438\u043c\u0438 \u0441\u043d\u044d\u043f\u0448\u043e\u0442\u0430\u043c\u0438 \u043a\u0443\u0447\u0430 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0439. \u0418 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u044f \u043d\u0430 \u0440\u0435\u0434\u0430\u043a\u0446\u0438\u044e \u0441\u0435\u0440\u0432\u0435\u0440\u0430, \u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u0411\u0414 \u043f\u0430\u0434\u0430\u0435\u0442, \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0442 \u043a \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u043c\u0443 \u0441\u043d\u0438\u043c\u043a\u0443 \u0432\u043e\u0437\u043c\u043e\u0436\u0435\u043d, \u0442\u043e\u043b\u044c\u043a\u043e \u0435\u0441\u043b\u0438 \u043e\u043d \u043e\u0434\u0438\u043d, \u0438 \u0440\u0430\u0437\u043c\u0435\u0440\u044b \u043d\u0430 \u0434\u0438\u0441\u043a\u0435 \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e, \u0438 \u0441 \u0440\u0430\u0437\u043d\u044b\u043c\u0438 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u0444\u0438\u0447\u0430\u043c\u0438 \u043c\u043e\u0436\u043d\u043e \u043d\u0430\u0440\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438. \u041a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u2014 <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/relational-databases\/databases\/database-snapshots-sql-server\" rel=\"nofollow noopener noreferrer\">\u0447\u0438\u0442\u0430\u0439\u0442\u0435 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e<\/a>. \u042f \u043c\u043e\u0433\u0443 \u0441\u0435\u0431\u0435 \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0442\u0430\u043a\u043e\u0433\u043e \u0432 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u043e\u0432\u043e\u043c \u043a\u043e\u043d\u0442\u0443\u0440\u0435, \u043d\u043e \u0432 \u043a\u0430\u043a\u0438\u0445-\u0442\u043e \u0433\u0440\u0430\u043d\u0438\u0447\u043d\u044b\u0445 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u2014 \u0440\u0430\u0437\u0432\u0435 \u0447\u0442\u043e \u0434\u043b\u044f \u043a\u0430\u043a\u0438\u0445-\u0442\u043e \u043c\u0430\u0441\u0441\u043e\u0432\u044b\u0445 ETL, \u0442\u0440\u0435\u0431\u0443\u044e\u0449\u0438\u0445 \u043a\u043e\u043d\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u0438 \u0438\u043b\u0438 \u0447\u0435\u0433\u043e-\u0442\u043e \u043f\u043e\u0434\u043e\u0431\u043d\u043e\u0433\u043e, \u043d\u043e \u0438 \u0432 \u044d\u0442\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0435\u0441\u0442\u044c \u0438\u0434\u0435\u0438 \u043f\u043e\u043b\u0443\u0447\u0448\u0435, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0443\u0440\u043e\u0432\u0435\u043d\u044c \u0438\u0437\u043e\u043b\u044f\u0446\u0438\u0438 snapshot \u0438\u043b\u0438 AlwaysOn \u0440\u0435\u043f\u043b\u0438\u043a\u0443 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c. \u0410 \u0432\u043e\u0442 \u0432 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0435 \u0441\u043d\u0438\u043c\u043a\u0438 \u043f\u0440\u043e\u044f\u0432\u043b\u044f\u044e\u0442 \u0441\u0435\u0431\u044f \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e. \u0420\u0430\u0437\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c \u0441\u0440\u0435\u0434\u0443, \u0441\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u043d\u0438\u043c\u043e\u043a, \u0440\u0430\u0437\u0432\u043b\u0435\u043a\u0430\u0435\u043c\u0441\u044f, \u0435\u0441\u043b\u0438 \u0447\u0442\u043e-\u0442\u043e \u043d\u0435 \u0442\u0430\u043a, \u0442\u043e \u0431\u044b\u0441\u0442\u0440\u043e \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u043c &#171;\u043a\u0430\u043a \u0431\u044b\u043b\u043e&#187;. \u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0441\u043d\u0438\u043c\u043a\u0430 \u0437\u0430\u043d\u0438\u043c\u0430\u0435\u0442 \u0441\u0435\u043a\u0443\u043d\u0434\u044b, \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0435\u043d\u0438\u0435 \u043a \u0441\u043d\u0438\u043c\u043a\u0443 \u2014 \u043e\u0442 \u0441\u0438\u043b\u044b \u043c\u0438\u043d\u0443\u0442\u044b. \u0412\u0441\u0451, \u0437\u0430\u0434\u0430\u0447\u0430 \u0440\u0435\u0448\u0435\u043d\u0430, \u043c\u043e\u0436\u0435\u043c \u0440\u0430\u0441\u0445\u043e\u0434\u0438\u0442\u044c\u0441\u044f? \u041d\u0435 \u0441\u043f\u0435\u0448\u0438\u0442\u0435. \u041d\u0430\u043c \u0432\u0441\u0451 \u0435\u0449\u0435 \u043d\u0443\u0436\u043d\u044b \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u0438\u043b\u0438 \u0441\u043e\u0442\u043d\u0438 \u0441\u0440\u0435\u0434. \u0418 \u0447\u0435\u043c \u0431\u043e\u043b\u044c\u0448\u0435, \u0442\u0435\u043c \u043b\u0443\u0447\u0448\u0435. \u0410 \u043f\u0435\u0442\u0430\u0431\u0430\u0439\u0442\u043d\u043e\u0435 \u0445\u0440\u0430\u043d\u0438\u043b\u0438\u0449\u0435 \u0432\u0441\u0451 \u0435\u0449\u0435 \u0431\u0438\u0437\u043d\u0435\u0441 \u043d\u0435 \u043a\u0443\u043f\u0438\u043b \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0430\u043c. \u0418 \u0432\u0441\u0451 \u0435\u0449\u0435 \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u043d\u0438\u0435 \u043d\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0443\u0440\u0430 \u2014 \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u043c\u0438\u043d\u0443\u0442 \u0438 \u0447\u0430\u0441\u044b.<\/p>\n<p>  <\/p>\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/bx\/1l\/qf\/bx1lqfch6unulzf8krqzly1067o.png\" alt=\"\u041a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0438\u0437 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438\" data-src=\"https:\/\/habrastorage.org\/webt\/bx\/1l\/qf\/bx1lqfch6unulzf8krqzly1067o.png\"\/><br \/>  <em>\u041a\u0430\u0440\u0442\u0438\u043d\u043a\u0430 \u0438\u0437 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 database snapshots<\/em><\/p>\n<p>  <\/p>\n<p>\u041d\u043e, \u043a \u0441\u0447\u0430\u0441\u0442\u044c\u044e, \u0434\u043b\u044f \u0442\u0435\u0445, \u0443 \u043a\u043e\u0433\u043e SQL Serer 2017 \u0438\u043b\u0438 2019 \u0432\u044b\u0445\u043e\u0434 \u0435\u0441\u0442\u044c. \u041d\u0435 \u0432\u0441\u0435\u043c, \u043d\u043e \u043c\u043d\u043e\u0433\u0438\u043c \u043f\u043e\u0434\u043e\u0439\u0434\u0451\u0442. SQL Server \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 2017 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u0440\u0430\u0437\u0432\u0451\u0440\u043d\u0443\u0442 \u043d\u0430 linux. \u0412 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u0435 SQL Server \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043d\u0430 Linux \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u0442\u044c \u043d\u0435 \u0431\u0443\u0434\u0443\u0442, \u0443\u0436 \u0441\u043b\u0438\u0448\u043a\u043e\u043c \u043c\u043d\u043e\u0433\u043e \u043d\u044e\u0430\u043d\u0441\u043e\u0432. \u041d\u043e \u043c\u044b \u0436\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438. \u041d\u0430\u043c \u043f\u043b\u0435\u0432\u0430\u0442\u044c \u0443\u0436\u0435 \u0434\u0430\u0436\u0435 \u043d\u0430 \u0432\u0442\u043e\u0440\u0443\u044e \u0434\u0435\u0432\u044f\u0442\u043a\u0443 \u0432 \u043d\u0435\u043f\u0440\u0435\u0440\u044b\u0432\u043d\u043e\u0441\u0442\u0438. \u0423 \u043d\u0430\u0441 \u0441\u0435\u0440\u0432\u0435\u0440 \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e \u043d\u0435 \u0442\u0430\u043a\u043e\u0439 \u0431\u044b\u0441\u0442\u0440\u044b\u0439, \u043a\u0430\u043a \u0432 \u043f\u0440\u043e\u0434\u0435 (\u043b\u0438\u0448\u044c \u0431\u044b \u043f\u043b\u0430\u043d\u044b \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u0432\u043e\u0441\u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u043b\u0438\u0441\u044c), \u0438 \u043c\u044b \u0433\u043e\u0442\u043e\u0432\u044b \u043a \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0430\u043c. \u041c\u044b \u0436\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u0438! \u041d\u043e \u0447\u0435\u043c \u0436\u0435 \u043d\u0430\u043c \u043f\u043e\u043c\u043e\u0436\u0435\u0442 Linux? \u0410 \u0432 \u043d\u0451\u043c \u0435\u0441\u0442\u044c \u0444\u0430\u0439\u043b\u043e\u0432\u044b\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b (\u0424\u0421), \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0443\u0436\u0435 \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u0443\u043c\u0435\u044e\u0442 \u0432 CoW. \u0412 \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043e\u043f\u0438\u0448\u0443 XFS \u0438 BTRFS.<\/p>\n<p>  <\/p>\n<p>\u0418\u0442\u0430\u043a, \u0443\u0442\u043e\u0447\u043d\u0438\u043c \u0437\u0430\u0434\u0430\u0447\u0443. \u041c\u044b \u043f\u043e\u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u0442\u0435\u043d\u0434 MS SQL Server, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0431\u0443\u0434\u0443\u0442 \u0440\u0430\u0441\u043f\u043e\u043b\u0430\u0433\u0430\u0442\u044c\u0441\u044f \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0445 \u0431\u0430\u0437 \u0434\u0430\u043d\u043d\u044b\u0445, \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0431\u044b\u0441\u0442\u0440\u043e (\u0441\u0435\u043a\u0443\u043d\u0434\u044b) \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0435 \u0431\u0430\u0437\u044b \u0438\u0437 \u0448\u0430\u0431\u043b\u043e\u043d\u0430, \u0434\u0430 \u0435\u0449\u0435 \u0438 \u0442\u0430\u043a, \u0447\u0442\u043e\u0431\u044b \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0430\u044f \u0442\u0435\u0441\u0442\u043e\u0432\u0430\u044f \u0411\u0414 \u0437\u0430\u043d\u0438\u043c\u0430\u043b\u0430 \u0440\u043e\u0432\u043d\u043e \u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043c\u0435\u0441\u0442\u0430, \u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432 \u043d\u0435\u0439 \u043f\u0440\u043e\u0438\u0437\u043e\u0448\u043b\u043e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0437\u0430 \u0441\u0447\u0451\u0442 CoW.<\/p>\n<p>  <\/p>\n<p>\u0414\u0430\u043b\u0435\u0435 \u044f \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u044e, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u0441\u0442\u0435\u043d\u0434, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0435 \u0436\u0430\u043b\u043a\u043e, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u043d\u0435\u0442 \u0434\u0430\u0436\u0435 \u0431\u0430\u0437 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438, \u043d\u0430 \u0434\u0430\u043d\u043d\u043e\u0439 \u043c\u0430\u0448\u0438\u043d\u0435 \u0443 \u0432\u0430\u0441 \u043f\u043e\u043b\u043d\u044b\u0435 \u043f\u0440\u0430\u0432\u0430 (\u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u044f \u0440\u0430\u0431\u043e\u0442\u0430 \u0441 \u0424\u0421 \u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u041f\u041e \u0442\u0440\u0435\u0431\u0443\u0435\u0442 <code>root<\/code>-\u0434\u043e\u0441\u0442\u0443\u043f\u0430), \u0438 \u0432 \u0446\u0435\u043b\u043e\u043c \u0432\u044b \u0441 linux \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u0437\u043d\u0430\u043a\u043e\u043c\u044b, \u043a\u043e\u043c\u0430\u043d\u0434\u044b <code>du<\/code>\/<code>df<\/code>\/<code>lsblk<\/code> \u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u043d\u0435 \u043f\u0443\u0433\u0430\u044e\u0442, \u043c\u043d\u043e\u0433\u0438\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 &#171;\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b \u0432\u0441\u0435\u043c&#187; \u0438\u043b\u0438 &#171;\u043b\u0435\u0433\u043a\u043e \u0433\u0443\u0433\u043b\u044f\u0442\u0441\u044f&#187; \u044f \u043d\u0435 \u0431\u0443\u0434\u0443 \u0440\u0430\u0437\u0436\u0451\u0432\u044b\u0432\u0430\u0442\u044c. \u041a\u043e\u043c\u0430\u043d\u0434\u044b, \u0442\u0440\u0435\u0431\u0443\u044e\u0449\u0438\u0435 <code>root<\/code>-\u0434\u043e\u0441\u0442\u0443\u043f\u0430 \u0432 \u0442\u0435\u043a\u0441\u0442\u0435 \u0441\u0442\u0430\u0442\u044c\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 <code>sudo<\/code>, \u0447\u0442\u043e\u0431\u044b \u0443\u0434\u043e\u0431\u043d\u0435\u0435 \u0431\u044b\u043b\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u0432 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 &#171;\u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e&#187;.<\/p>\n<p>  <\/p>\n<p>SQL Server \u043d\u0430 Linux \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430 \u0442\u0440\u0451\u0445 \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0442\u0438\u0432\u0430\u0445: RHEL, Ubuntu \u0438 Suse. \u041d\u0443 \u0438 \u0432 docker-\u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u0445, \u043d\u043e \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u043e\u043d\u0438 \u043d\u0435 \u043f\u043e\u0434\u043e\u0448\u043b\u0438. \u041d\u0430 <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/linux\/quickstart-install-connect-ubuntu\" rel=\"nofollow noopener noreferrer\">Ubuntu<\/a> \u0432\u0441\u0451 \u043d\u0438\u0436\u0435\u043f\u0435\u0440\u0435\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u043e\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u043d\u043e \u043c\u0435\u043d\u044f \u0442\u0443\u0442 \u043f\u043e\u043f\u0440\u043e\u0441\u0438\u043b\u0438 \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u043d\u0430 Oracle Linux (OL), \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0441\u0435\u0439\u0447\u0430\u0441 \u0441\u0442\u0435\u043d\u0434 \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u043b \u043d\u0430 \u043d\u0451\u043c. OL \u2014 \u044d\u0442\u043e \u043f\u043e\u0447\u0442\u0438-\u043f\u043e\u0447\u0442\u0438 \u043a\u043b\u043e\u043d RHEL.<\/p>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u041f\u043e\u0447\u0435\u043c\u0443 \u043d\u0435 \u043f\u043e\u0434\u043e\u0448\u043b\u0438 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b.<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<p>\u041c\u044b \u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u0432\u044b\u0438\u0433\u0440\u0430\u0442\u044c \u0434\u0438\u0441\u043a\u043e\u0432\u043e\u0435 \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e, \u0430 \u0441 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430\u043c\u0438 \u044d\u0442\u043e \u043d\u0435 \u0442\u0430\u043a \u043f\u0440\u043e\u0441\u0442\u043e. \u041e\u0431\u044b\u0447\u043d\u043e \u043c\u043d\u043e\u0433\u043e \u043c\u0435\u0441\u0442\u0430 \u043d\u0443\u0436\u043d\u043e \u043d\u0430 \u0441\u0430\u043c\u0443 \u0441\u0431\u043e\u0440\u043a\u0443 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u0430. \u041f\u043b\u044e\u0441, \u0435\u0441\u043b\u0438 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u0441\u0442\u0435\u043d\u0434 \u044d\u0442\u043e \u043e\u0434\u043d\u0430 \u0411\u0414, \u0442\u043e \u0443 \u043d\u0430\u0441 \u0432\u043e\u0437\u043d\u0438\u043a\u043d\u0443\u0442 \u0440\u0430\u0441\u0445\u043e\u0434\u044b \u043d\u0430 \u0441\u0430\u043c \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440, \u0438, \u0447\u0442\u043e \u0431\u043e\u043b\u0435\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043d\u0430 <code>tempdb<\/code>. \u041f\u043e\u044d\u0442\u043e\u043c\u0443 \u043a\u043e\u043d\u0442\u0435\u0439\u043d\u0435\u0440\u044b \u2014 \u044d\u0442\u043e \u043f\u0440\u0435\u043a\u0440\u0430\u0441\u043d\u043e, \u043d\u043e \u043c\u044b \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u043e\u0434\u0438\u043d \u0441\u0442\u0435\u043d\u0434 \u043d\u0430 \u0431\u043e\u043b\u044c\u0448\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0431\u0430\u0437 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<\/div><\/div>\n<p>  <\/p>\n<div class=\"spoiler\" role=\"button\" tabindex=\"0\">                         <b class=\"spoiler_title\">\u0418\u0437 \u0447\u0430\u0442\u0430 \u0441 \u0430\u0434\u043c\u0438\u043d\u043e\u043c &#8212; \u043f\u043e\u0448\u043b\u0430\u044f \u0448\u0443\u0442\u043a\u0430 \u043f\u0440\u043e \u0440\u0430\u0437\u043d\u0438\u0446\u0443 RHEL \u0438 OL<\/b>                         <\/p>\n<div class=\"spoiler_text\">\n<p>\u0410\u0434\u043c\u0438\u043d: \u0434\u0430, \u043e\u043d\u0438 \u0441\u0438\u043b\u044c\u043d\u043e-\u0441\u0438\u043b\u044c\u043d\u043e \u043f\u043e\u0445\u043e\u0436\u0438<br \/>  \u0410\u0434\u043c\u0438\u043d: \u0435\u0441\u043b\u0438 \u0431\u044b \u044d\u0442\u043e \u0431\u044b\u043b\u0438 \u0441\u0435\u0441\u0442\u0440\u044b-\u0431\u043b\u0438\u0437\u043d\u044f\u0448\u043a\u0438 \u2014 \u0441\u043f\u0430\u043b \u0431\u044b \u0441 \u043e\u0431\u0435\u0438\u043c\u0438 \u0438 \u0433\u043e\u0432\u043e\u0440\u0438\u043b, \u0431\u044b \u0447\u0442\u043e \u043f\u0435\u0440\u0435\u043f\u0443\u0442\u0430\u043b<br \/>  \u042f: \u0431\u0435\u0437 <code>uname -a<\/code> \u0438 \u0432 \u0442\u0435\u043c\u043d\u043e\u0442\u0435 \u2014 \u043a\u0430\u043a \u043d\u0435 \u043f\u0435\u0440\u0435\u043f\u0443\u0442\u0430\u0442\u044c?<br \/>  \u0410\u0434\u043c\u0438\u043d: \u0445\u0435\u0445\u0435)<br \/>  \u0410\u0434\u043c\u0438\u043d: \u0442\u044b \u043f\u0440\u043e \u0441\u0435\u0441\u0442\u0435\u0440 \u0438\u043b\u0438 \u0441\u0435\u0440\u0432\u0435\u0440?)<\/p>\n<\/div><\/div>\n<p>  <\/p>\n<p>\u0423\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u043d\u0430\u043c \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u0430 \u0441\u0430\u043c\u0430\u044f \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f, \u043d\u0438\u0447\u0435\u0433\u043e \u043a\u0440\u043e\u043c\u0435 \u0441\u0435\u0442\u0438, SSH \u0438 \u0443\u0442\u0438\u043b\u0438\u0442 \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0424\u0421 \u043d\u0430\u043c \u043d\u0435 \u043d\u0430\u0434\u043e. \u0421\u0442\u0430\u0432\u0438\u0442\u044c \u043c\u043e\u0436\u0435\u0442\u0435 \u043b\u044e\u0431\u044b\u043c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c: \u0432\u0437\u044f\u0442\u044c \u0433\u043e\u0442\u043e\u0432\u0443\u044e \u0432\u0438\u0440\u0442\u0443\u0430\u043b\u044c\u043d\u0443\u044e \u043c\u0430\u0448\u0438\u043d\u0443 \u0443 \u0430\u0434\u043c\u0438\u043d\u043e\u0432, \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u044c \u0447\u0435\u0440\u0435\u0437 \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c <a href=\"https:\/\/access.redhat.com\/documentation\/en-us\/red_hat_enterprise_linux\/8\/html-single\/configuring_and_managing_cloud-init_for_rhel_8\/index\" rel=\"nofollow noopener noreferrer\">cloud-init (\u0441\u0441\u044b\u043b\u043a\u0430 \u0434\u043b\u044f RHEL)<\/a> \u0438\u043b\u0438 <a href=\"https:\/\/docs.oracle.com\/en\/operating-systems\/oracle-linux\/8\/install\/install-AutomatinganOracleLinuxInstallationbyUsingKickstart.html\" rel=\"nofollow noopener noreferrer\">kickstart<\/a> \u0438\u043b\u0438 \u0447\u0435\u043c \u0442\u0430\u043c \u0443 \u0432\u0430\u0441 \u043f\u0440\u0438\u043d\u044f\u0442\u043e \u0440\u0430\u0437\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0442\u044c, \u0430 \u043c\u043e\u0436\u0435\u0442\u0435 \u0432\u043e\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f <a href=\"https:\/\/docs.oracle.com\/en\/operating-systems\/oracle-linux\/8\/install\/install-InstallingOracleLinuxManually.html#install-text-mode\" rel=\"nofollow noopener noreferrer\">\u0440\u0443\u0447\u043d\u043e\u0439 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u043e\u0439<\/a> \u0432 \u0442\u0435\u043a\u0441\u0442\u043e\u0432\u043e\u043c \u0440\u0435\u0436\u0438\u043c\u0435 (\u043d\u0435 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e &#171;\u0433\u0440\u0430\u0444\u0438\u0447\u0435\u0441\u043a\u0438\u0439&#187; \u0440\u0435\u0436\u0438\u043c \u2014 \u043e\u043d \u0432\u0430\u043c \u043d\u0430 \u044d\u0442\u043e\u0439 \u043c\u0430\u0448\u0438\u043d\u0435 \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f, \u0438 \u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0412\u041c \u0432 \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u043e\u043c \u0440\u0430\u0437\u0440\u0435\u0448\u0435\u043d\u0438\u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u043d\u0435\u0443\u0434\u043e\u0431\u043d\u043e). \u0414\u0438\u0441\u043a\u0438 \u043c\u043e\u0436\u0435\u0442\u0435 \u0440\u0430\u0437\u043c\u0435\u0447\u0430\u0442\u044c \u043a\u0430\u043a \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u0435\u0435: \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0440\u0430\u0437\u0434\u0435\u043b ext4 \u0434\u043b\u044f \u043a\u043e\u0440\u043d\u044f <code>\/<\/code>, \u0440\u0430\u0437\u0434\u0435\u043b SWAP \u0438 XFS-\u0440\u0430\u0437\u0434\u0435\u043b \u0434\u043b\u044f <code>\/home<\/code> \u2014 \u043f\u0440\u043e\u0441\u0442\u043e \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043f\u0440\u0438\u0432\u044b\u0447\u043d\u0435\u0435. \u0414\u043b\u044f \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u043e\u0432 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u0440\u0430\u0437\u0434\u0435\u043b\u044b, \u043d\u0435 \u0437\u0430\u0431\u0443\u0434\u044c\u0442\u0435 \u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c \u0434\u043b\u044f \u043d\u0438\u0445 \u043c\u0435\u0441\u0442\u043e, \u0435\u0441\u043b\u0438 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u0443\u0435\u0442\u0435 \u043d\u0430 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0436\u0435\u043b\u0435\u0437\u043a\u0435.<br \/>  \u041e\u0442\u043c\u0435\u0447\u0443 \u0435\u0449\u0451, \u0447\u0442\u043e \u0431\u0430\u0437\u043e\u0432\u044b\u0435 \u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u0438 OL \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0441\u043a\u0443\u0434\u043d\u044b, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u0442\u044c\u0441\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c EPEL (Extra Packages for Enterprise Linux). \u041c\u043d\u0435, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043e\u043d\u0438 \u043f\u043e\u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043b\u0438\u0441\u044c \u0434\u043b\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438 \u043f\u0430\u043a\u0435\u0442\u043e\u0432 \u0434\u043b\u044f \u0440\u0430\u0441\u043f\u0430\u043a\u043e\u0432\u043a\u0438 7z-\u0444\u0430\u0439\u043b\u043e\u0432, \u043d\u0443 \u0438 <code>htop<\/code> \u043e\u0442\u0442\u0443\u0434\u0430 \u0437\u0430\u043e\u0434\u043d\u043e \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043b. \u0414\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0438 \u0441\u0442\u0430\u0432\u0438\u043b OL 8.6 \u0441\u043e \u0432\u0441\u0435\u043c\u0438 \u0430\u043f\u0434\u0435\u0439\u0442\u0430\u043c\u0438.<\/p>\n<p>  <\/p>\n<p>\u0411\u0430\u0437\u043e\u0432\u0430\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 SQL Server \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u0430\u044f. \u0421\u0442\u0440\u043e\u0447\u043a\u0430 \u0437\u0430 \u0441\u0442\u0440\u043e\u0447\u043a\u043e\u0439 \u0438\u0437 <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/linux\/quickstart-install-connect-red-hat\" rel=\"nofollow noopener noreferrer\">\u043c\u0430\u043d\u0443\u0430\u043b\u0430<\/a> \u2014 \u0442\u043e\u043b\u044c\u043a\u043e \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u0435\u0435 \u0441 \u0432\u0435\u0440\u0441\u0438\u044f\u043c\u0438 SQL Server: \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0443\u0436\u0435 \u043e\u0442\u043a\u0440\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0441\u0442\u0430\u0442\u044c\u044f \u043f\u0440\u043e SQL Server 2022. \u041d\u043e \u0435\u0441\u043b\u0438 \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0434\u043e\u043f\u043e\u043b\u043d\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044f, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0435\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u0430 <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/linux\/sql-server-linux-ad-auth-adutil-tutorial\" rel=\"nofollow noopener noreferrer\">\u0430\u0443\u0442\u0435\u043d\u0442\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f AD<\/a> \u2014 \u0447\u0442\u043e \u0442\u0438\u043f\u0438\u0447\u043d\u043e \u0434\u043b\u044f \u044d\u043d\u0442\u0435\u0440\u043f\u0440\u0430\u0439\u0437\u0430, \u0442\u043e \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0433\u043b\u0443\u0431\u0436\u0435 \u043f\u043e\u0433\u0440\u0443\u0437\u0438\u0442\u044c\u0441\u044f \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e. \u041d\u0443 \u0438, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c \u043f\u0440\u043e \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0443 collation, \u043a\u043b\u044e\u0447\u0435\u0439 \u0437\u0430\u043f\u0443\u0441\u043a\u0430, \u0444\u043b\u0430\u0433\u043e\u0432 \u0442\u0440\u0430\u0441\u0441\u0438\u0440\u043e\u0432\u043a\u0438 (\u0435\u0441\u043b\u0438 \u0432\u0430\u043c \u043d\u0443\u0436\u043d\u044b), \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0443 tempdb (\u043e\u043f\u044f\u0442\u044c \u0436\u0435 \u2014 \u0435\u0441\u043b\u0438 \u043d\u0430\u0434\u043e)<\/p>\n<p>  <\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u043e \u0424\u0421. \u041e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e SQL Server <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/linux\/sql-server-linux-faq\" rel=\"nofollow noopener noreferrer\">\u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442<\/a> ext4 \u0438 XFS, \u043f\u0440\u0438\u0447\u0435\u043c, \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u044f \u0437\u043d\u0430\u044e, ext4 <a href=\"https:\/\/www.ctrl.blog\/entry\/file-cloning.html\" rel=\"nofollow noopener noreferrer\">\u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442<\/a> CoW. ZFS, \u0438\u0437\u0432\u0438\u043d\u0438\u0442\u0435, \u043d\u0435 \u043f\u0440\u043e\u0431\u043e\u0432\u0430\u043b, \u043d\u043e \u0432\u043e\u0442 \u0431\u0435\u0433\u043b\u044b\u0435 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u044b \u0441 BTRFS \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442, \u0447\u0442\u043e \u0441 BTRFS \u0432\u0441\u0451 \u0442\u043e\u0436\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f. BTRFS \u0441\u043f\u0435\u0446\u0438\u0444\u0438\u0447\u043d\u0430\u044f \u0424\u0421, \u0432 \u043d\u0435\u0439 CoW \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u2014 \u0432 \u0442\u043e\u043c \u0447\u0438\u0441\u043b\u0435 \u0438\u0437-\u0437\u0430 \u044d\u0442\u043e\u0433\u043e, \u0434\u0430\u0436\u0435 \u043f\u0440\u0438 \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u043c \u0435\u0451 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438, \u043e\u043d\u0430 \u043c\u0435\u0434\u043b\u0435\u043d\u043d\u0435\u0435 XFS \u0432\u043e \u043c\u043d\u043e\u0433\u0438\u0445 \u0442\u0435\u0441\u0442\u0430\u0445. \u041c\u043e\u0436\u0435\u0442 \u0438 \u043d\u0430\u0434\u0451\u0436\u043d\u043e\u0441\u0442\u044c \u043a\u0430\u043a\u0430\u044f-\u0442\u043e \u043d\u0435 \u0442\u0430\u043a\u0430\u044f, \u043d\u043e \u0432 \u0434\u0430\u043d\u043d\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435 \u043d\u0430\u043c \u043d\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438, \u043d\u0438 \u0441\u0443\u043f\u0435\u0440\u043d\u0430\u0434\u0451\u0436\u043d\u043e\u0441\u0442\u0438 \u0432\u0440\u043e\u0434\u0435 \u043d\u0435 \u043d\u0430\u0434\u043e, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043e\u043f\u0438\u0448\u0443 \u043f\u043b\u044e\u0441\u044b \u0438 \u043c\u0438\u043d\u0443\u0441\u044b \u0434\u043b\u044f \u043e\u0431\u0435\u0438\u0445 \u0424\u0421.<\/p>\n<p>  <\/p>\n<p>\u0418\u0442\u0430\u043a, \u0441\u0447\u0438\u0442\u0430\u0435\u043c, \u0447\u0442\u043e SQL Server \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0441\u044f \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u0432 <code>\/opt\/mssql<\/code>, \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043b\u0435\u0436\u0430\u0442 \u0432 <code>\/var\/opt\/mssql\/data<\/code>, \u0441\u043b\u0443\u0436\u0431\u0430 <code>mssql-server.service<\/code> \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, SSMS \u043f\u043e \u043e\u0431\u044b\u0447\u043d\u043e\u043c\u0443 \u043f\u043e\u0440\u0442\u0443 1433 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u0442\u0441\u044f, \u043d\u0430\u0447\u0438\u043d\u0430\u0435\u043c \u0440\u0430\u0437\u0432\u043b\u0435\u043a\u0430\u0442\u044c\u0441\u044f.<\/p>\n<p>  <\/p>\n<p><strong>\u0412\u0430\u0436\u043d\u043e\u0435 \u043f\u0440\u0435\u0434\u0443\u043f\u0440\u0435\u0436\u0434\u0435\u043d\u0438\u0435<\/strong>: \u043d\u0438\u0436\u0435 \u043f\u0440\u0438\u0432\u043e\u0434\u044f\u0442\u0441\u044f \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0434\u043b\u044f \u043c\u043e\u0435\u0433\u043e \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0438\u043e\u043d\u043d\u043e\u0433\u043e \u0441\u0442\u0435\u043d\u0434\u0430. \u041e\u043d\u0438 \u0434\u0430\u043d\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u0430. \u041e\u043d\u0438 \u043c\u043e\u0433\u0443\u0442 \u0443 \u0432\u0430\u0441 \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c. \u041c\u043d\u043e\u0433\u0438\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043c\u043e\u0433\u0443\u0442 \u0431\u044b\u0442\u044c \u0440\u0430\u0437\u0440\u0443\u0448\u0438\u0442\u0435\u043b\u044c\u043d\u044b \u0434\u043b\u044f \u0442\u043e\u0439 \u041e\u0421 \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043e\u043d\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u044e\u0442\u0441\u044f (\u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u043f\u043e\u0447\u0442\u0438 \u0432\u0441\u0435 \u0441 sudo). \u041d\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0439\u0442\u0435 \u0438\u0445, \u0435\u0441\u043b\u0438 \u043d\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u0435\u0442\u0435, \u0447\u0442\u043e \u043f\u0440\u043e\u0438\u0437\u043e\u0439\u0434\u0451\u0442. \u041d\u0435 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0439\u0442\u0435 \u0438\u0445 \u0432\u043d\u0435 \u0441\u0442\u0435\u043d\u0434\u0430, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0435 \u0436\u0430\u043b\u043a\u043e \u043f\u043e\u0442\u0435\u0440\u044f\u0442\u044c \u0438\u043b\u0438 \u043b\u0435\u0433\u043a\u043e \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c. \u0415\u0441\u043b\u0438 \u0432\u044b \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442\u0435 \u043f\u043e ssh, \u043d\u0435 \u0437\u0430\u0431\u0443\u0434\u044c\u0442\u0435 \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c, \u043d\u0430 \u043a\u0430\u043a\u043e\u043c \u0445\u043e\u0441\u0442\u0435 \u0432\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0435 \u043a\u043e\u043c\u0430\u043d\u0434\u044b.<\/p>\n<p>  <\/p>\n<h2 id=\"xfs\">XFS<\/h2>\n<p>  <\/p>\n<p>\u041a\u0440\u0430\u0442\u043a\u043e \u043e\u0431 XFS. \u0412\u0435\u0441\u044c\u043c\u0430 \u043f\u043e\u0447\u0442\u0435\u043d\u043d\u0430\u044f \u0434\u043e\u0431\u0440\u043e\u0442\u043d\u0430\u044f \u0424\u0421, \u0441\u043e\u0437\u0434\u0430\u043d\u043d\u0430\u044f \u0432 1993 \u0433\u043e\u0434\u0443, \u043f\u0440\u0438\u0448\u0435\u0434\u0448\u0430\u044f \u043d\u0430 Linux \u0432 2001 \u0433\u043e\u0434\u0443, \u0434\u043e\u043b\u0433\u043e\u0435 \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u043b\u0430\u0441\u044c \u043d\u0435\u043f\u043e\u0439\u043c\u0438 \u043a\u0430\u043a. 10 \u043b\u0435\u0442 \u043d\u0430\u0437\u0430\u0434, \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0442\u043e\u043b\u044c\u043a\u043e OpenSuse \u0438\u0437 \u0431\u043e\u043b\u0435\u0435-\u043c\u0435\u043d\u0435\u0435 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0442\u0438\u0432\u043e\u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0435\u0451 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e (\u0434\u043b\u044f <code>\/home<\/code>). \u0412 2014-2016 \u0433\u043e\u0434\u0443 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430 \u0437\u0430\u0440\u044f\u0434 \u0431\u043e\u0434\u0440\u043e\u0441\u0442\u0438 (\u043a\u043e\u043c\u043c\u0438\u0442\u044b \u043d\u0435 \u0430\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043b, \u043d\u043e, \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e, \u0441\u0432\u044f\u0437\u0430\u043d\u043e \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e Red Hat \u043d\u0430\u0447\u0430\u043b \u0435\u0451 \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0442\u044c) \u0438 \u0432\u0441\u043a\u043e\u0440\u0435 \u0437\u0430\u0432\u0435\u0437\u043b\u0438 \u043d\u0443\u0436\u043d\u0443\u044e \u043d\u0430\u043c \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0443\u043f\u0440\u0430\u0436\u043d\u0435\u043d\u0438\u0438 CoW.<\/p>\n<p>  <\/p>\n<h3 id=\"podgotovka-razdela\">\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 \u0440\u0430\u0437\u0434\u0435\u043b\u0430<\/h3>\n<p>  <\/p>\n<p>\u041f\u0443\u0441\u0442\u044c \u0434\u043b\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u0424\u0421 \u0443 \u043d\u0430\u0441 \u0435\u0441\u0442\u044c \u0441\u044b\u0440\u043e\u0435 \u0431\u043b\u043e\u0447\u043d\u043e\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u043e <code>sdb<\/code>. \u0420\u0430\u0437\u043c\u0435\u0442\u0438\u043c \u0435\u0433\u043e. \u041b\u0438\u0447\u043d\u043e \u044f \u043f\u0440\u0435\u0434\u043f\u043e\u0447\u0438\u0442\u0430\u044e <code>parted<\/code>, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0432 \u0441\u043a\u0440\u0438\u043f\u0442\u0430\u0445 \u0443\u0434\u043e\u0431\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c, \u043d\u043e \u044d\u0442\u043e \u0432\u043a\u0443\u0441\u043e\u0432\u0449\u0438\u043d\u0430:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo parted --script \/dev\/sdb -- \\     unit MiB \\     mklabel gpt \\     mkpart primary xfs 1MiB 24GiB \\     name 1 sqlxfs \\     print<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u043d\u0443\u0442\u0440\u0438 <a href=\"https:\/\/wiki.archlinux.org\/title\/Parted\" rel=\"nofollow noopener noreferrer\"><code>parted<\/code><\/a> \u043c\u044b \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u043b\u0438 \u043a\u043e\u043c\u0430\u043d\u0434\u044b:<\/p>\n<p>  <\/p>\n<ul>\n<li><code>unit MiB<\/code> \u2014 \u0447\u0442\u043e\u0431\u044b \u0432\u044b\u0432\u043e\u0434 \u0431\u044b\u043b \u0432 \u043a\u0440\u0443\u0433\u043b\u044b\u0445 \u043f\u043e \u043e\u0441\u043d\u043e\u0432\u0430\u043d\u0438\u044e 2 <a href=\"https:\/\/ru.wikipedia.org\/wiki\/%D0%9C%D0%B5%D0%B1%D0%B8%D0%B1%D0%B0%D0%B9%D1%82\" rel=\"nofollow noopener noreferrer\">\u043c\u0435\u0431\u0438\u0431\u0430\u0439\u0442\u0430\u0445<\/a><\/li>\n<li><code>mklabel gpt<\/code> \u2014 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0440\u0430\u0437\u0434\u0435\u043b\u043e\u0432 GPT (\u0432 2022 \u0433\u043e\u0434\u0443 \u043d\u0435 \u0432\u0438\u0436\u0443 \u0441\u043c\u044b\u0441\u043b\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0442\u0430\u0431\u043b\u0438\u0446\u0443 \u0440\u0430\u0437\u0434\u0435\u043b\u043e\u0432 <code>msdos<\/code>)<\/li>\n<li><code>mkpart primary xfs 1MiB 24GiB<\/code> \u2014 \u0441\u043e\u0437\u0434\u0430\u043b\u0438 \u0440\u0430\u0437\u0434\u0435\u043b \u043f\u043e\u0447\u0442\u0438 \u043d\u0430 24 \u0413\u0438\u0411. \u0412\u043f\u0435\u0440\u0435\u0434\u0438 \u043e\u0441\u0442\u0430\u0432\u0438\u043b\u0438 1 \u041c\u0438\u0411 \u043d\u0430 \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u043d\u0438\u0435. \u041e\u0431\u0440\u0430\u0442\u0438\u0442\u0435 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440 <code>xfs<\/code> <strong>\u043d\u0435<\/strong> \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0424\u0421.<\/li>\n<li><code>name 1 sqlxfs<\/code> \u2014 \u043e\u0431\u043e\u0437\u0432\u0430\u043b\u0438 \u0440\u0430\u0437\u0434\u0435\u043b<\/li>\n<li><code>print<\/code> \u2014 \u043f\u043e\u043b\u044e\u0431\u043e\u0432\u0430\u043b\u0438\u0441\u044c \u043d\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442<\/li>\n<\/ul>\n<p>  <\/p>\n<p>\u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0424\u0421:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo mkfs.xfs \/dev\/sdb1 -f -L sqlxfs<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u044b\u0432\u043e\u0434 \u044d\u0442\u043e\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a\u043e\u0439:<\/p>\n<p>  <\/p>\n<pre><code class=\"plaintext\">meta-data=\/dev\/sdb1              isize=512    agcount=4, agsize=1572800 blks          =                       sectsz=512   attr=2, projid32bit=1          =                       crc=1        finobt=1, sparse=1, rmapbt=0          =                       reflink=1 data     =                       bsize=4096   blocks=6291200, imaxpct=25          =                       sunit=0      swidth=0 blks naming   =version 2              bsize=4096   ascii-ci=0, ftype=1 log      =internal log           bsize=4096   blocks=25600, version=2          =                       sectsz=512   sunit=0 blks, lazy-count=1 realtime =none                   extsz=4096   blocks=0, rtextents=0<\/code><\/pre>\n<p>  <\/p>\n<p>\u0418\u043c\u0435\u0435\u0442 \u0441\u043c\u044b\u0441\u043b \u043e\u0431\u0440\u0430\u0442\u0438\u0442\u044c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e <code>reflink=1<\/code>. \u0420\u0430\u0437\u043c\u0435\u0440 \u0431\u043b\u043e\u043a\u0430 \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e 4 \u041a\u0438\u0411: \u0442\u0435\u043e\u0440\u0435\u0442\u0438\u0447\u0435\u0441\u043a\u0438, \u043d\u0430\u0432\u0435\u0440\u043d\u043e\u0435, \u043b\u0443\u0447\u0448\u0435 \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u0442\u044c 8 \u041a\u0438\u0411 \u0434\u043b\u044f \u0432\u044b\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u043d\u0438\u044f \u043f\u043e \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u043c SQL Server, \u043d\u043e \u0432 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 <a href=\"https:\/\/linux.die.net\/man\/8\/mkfs.xfs\" rel=\"nofollow noopener noreferrer\">\u0441\u043a\u0430\u0437\u0430\u043d\u043e<\/a> &#171;XFS on Linux currently only supports pagesize or smaller blocks&#187; \u0438 \u044f \u0437\u0430\u0431\u0438\u043b.<\/p>\n<p>  <\/p>\n<p>\u0421\u043d\u0430\u0447\u0430\u043b\u0430 \u043f\u0440\u0438\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u043c &#171;\u043a\u0443\u0434\u0430 \u043f\u043e\u043f\u0430\u043b\u043e&#187; \u0438 \u0441\u0434\u0435\u043b\u0430\u0435\u043c \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\"># \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0447\u0442\u043e \u0443\u0436\u0435 \u0435\u0441\u0442\u044c \u0434\u0438\u0440\u0435\u043a\u0442\u043e\u0440\u0438\u044f \/tmp\/mnt\/xfs  sudo mount \/dev\/sdb1 \/tmp\/mnt\/xfs\/ -o noatime sudo mkdir \/tmp\/mnt\/xfs\/{template,work} sudo chown -R mssql:mssql \/tmp\/mnt\/xfs sudo umount \/tmp\/mnt\/xfs<\/code><\/pre>\n<p>  <\/p>\n<ul>\n<li><code>noatime<\/code> \u2014 \u043e\u043f\u0446\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0437\u0430\u043f\u0440\u0435\u0449\u0430\u0435\u0442 \u043f\u0440\u0438 \u043a\u0430\u0436\u0434\u043e\u043c \u043e\u0431\u0440\u0430\u0449\u0435\u043d\u0438\u0438 \u043a \u0444\u0430\u0439\u043b\u0430\u043c \u043f\u0438\u0441\u0430\u0442\u044c \u0432\u0440\u0435\u043c\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0433\u043e \u0434\u043e\u0441\u0442\u0443\u043f\u0430. \u0412 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u044d\u0442\u043e \u043d\u0435 \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u043e, \u043d\u043e \u0432\u043e\u043e\u0431\u0449\u0435 \u044d\u0442\u043e \u043b\u0443\u0447\u0448\u0435 \u0434\u0435\u043b\u0430\u0442\u044c \u043f\u043e \u0441\u043e\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f\u043c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438.<\/li>\n<li>\u0421\u043e\u0437\u0434\u0430\u0451\u043c 2 \u043f\u0430\u043f\u043a\u0438 <code>template<\/code> \u0438 <code>work<\/code> (\u0432\u044b, \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435 \u043c\u043e\u0436\u0435\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u0441\u0432\u043e\u044e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 \u043f\u0430\u043f\u043e\u043a)<\/li>\n<li>\u0421\u043e\u0437\u0434\u0430\u043d\u043d\u0443\u044e \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443 &#171;\u043e\u0442\u0434\u0430\u0451\u043c&#187; \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044e \u0438 \u043e\u0434\u043d\u043e\u0438\u043c\u0435\u043d\u043d\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0435 <code>mssql<\/code>. \u041f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043f\u0440\u0430\u0432\u0430 \u043a \u0444\u0430\u0439\u043b\u0430\u043c \u0421\u0423\u0411\u0414 \u0438\u043c\u0435\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0441\u0430\u043c\u0430 \u0421\u0423\u0411\u0414. \u0422\u0430\u043a\u043e\u0439 \u0440\u0443\u0447\u043d\u043e\u0439 <code>chown<\/code> \u043f\u0440\u0438 \u0434\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438 \u043b\u0443\u0447\u0448\u0435 \u043f\u0435\u0440\u0435\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c, \u043d\u043e \u0434\u043b\u044f \u0434\u0435\u043c\u043e \u2014 \u0441\u043e\u0439\u0434\u0451\u0442.<\/li>\n<li>\u0420\u0430\u0437\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u043c \u0440\u0430\u0437\u0434\u0435\u043b<\/li>\n<\/ul>\n<p>  <\/p>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0440\u0438\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u043c &#171;\u043a\u0443\u0434\u0430 \u043d\u0430\u0434\u043e&#187; \u0438 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e. \u042d\u0442\u043e \u0443\u0436\u0435 \u043d\u0443\u0436\u043d\u043e \u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c \u0432 <code>\/etc\/fstab<\/code> \u0438, \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435 \u043b\u0443\u0447\u0448\u0435 \u043f\u043e UUID, \u0430 \u043d\u0435 \u043f\u043e \u0438\u043c\u0435\u043d\u0438 <code>\/dev\/sdb1<\/code> \u0434\u0438\u0441\u043a\u0430. UUID c\u043c\u043e\u0442\u0440\u0438\u043c \u0432 <code>sudo blkid<\/code>. \u0415\u0441\u043b\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u043d\u0435 \u043e\u0442 \u0440\u0443\u0442\u0430, \u0442\u043e \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u0432\u044b \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0435 \u0443\u0432\u0438\u0434\u0438\u0442\u0435 <code>\/dev\/sdb1<\/code>. \u0422\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 <code>lsblk --output NAME,UUID \/dev\/sdb<\/code>. \u041f\u043e\u043b\u0443\u0447\u0435\u043d\u043d\u044b\u0439 UUID \u0432\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u043c \u0432 <code>fstab<\/code> \u043a\u0430\u043a-\u0442\u043e \u0442\u0430\u043a:<\/p>\n<p>  <\/p>\n<pre><code class=\"plaintext\">#... \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u0441\u0442\u0440\u043e\u0447\u043a\u0438 \u0432\u044b\u0448\u0435 ... UUID=25d2312b-4ccf-4e4d-b680-78cde1d83cd6 \/var\/opt\/mssql\/data\/xfs   xfs     defaults,noatime   0  0<\/code><\/pre>\n<p>  <\/p>\n<p>\u041d\u0435 \u0437\u0430\u0431\u0443\u0434\u044c\u0442\u0435 \u0441\u043e\u0437\u0434\u0430\u0442\u044c \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u0443\u044e <code>\/var\/opt\/mssql\/data\/xfs<\/code> \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u0438\u0442\u044c\/\u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0430 mssql \u043a \u043d\u0435\u0439. \u041f\u0435\u0440\u0435\u0437\u0430\u0433\u0440\u0443\u0436\u0430\u0435\u043c\u0441\u044f, \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 <code>mount<\/code>, \u0447\u0442\u043e \u0440\u0430\u0437\u0434\u0435\u043b \u0441\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043b\u0441\u044f \u043a\u0443\u0434\u0430 \u043d\u0443\u0436\u043d\u043e \u0438 \u043f\u0440\u0430\u0432\u0430 mssql \u043d\u0430 \u043c\u0435\u0441\u0442\u0435. \u041c\u043e\u0436\u043d\u043e \u043f\u0440\u0438\u0441\u0442\u0443\u043f\u0438\u0442\u044c \u043a \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u043d\u0438\u044e \u0431\u0430\u0437 \u0434\u0430\u043d\u043d\u044b\u0445.<\/p>\n<p>  <\/p>\n<h3 id=\"sozdanie-faylov-bd\">\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 \u0411\u0414<\/h3>\n<p>  <\/p>\n<p>\u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u0430 \u0432 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e <a href=\"https:\/\/www.brentozar.com\/archive\/2015\/10\/how-to-download-the-stack-overflow-database-via-bittorrent\/\" rel=\"nofollow noopener noreferrer\">\u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0435 \u0431\u0430\u0437\u044b<\/a> \u043c\u043d\u043e\u0433\u043e\u0443\u0432\u0430\u0436\u0430\u0435\u043c\u043e\u0433\u043e \u0411\u0440\u0435\u043d\u0442\u0430 \u041e\u0437\u0430\u0440\u0430 \u2014 \u043e\u043d\u0438 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u043f\u0443\u0431\u043b\u0438\u0447\u043d\u043e \u0438 \u0438\u043c\u0435\u044e\u0442 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u044b\u0439 \u043e\u0431\u044a\u0451\u043c. \u041e\u0447\u0435\u0432\u0438\u0434\u043d\u043e, \u0447\u0442\u043e \u0432 \u0432\u0430\u0448\u0435\u043c \u0443\u044e\u0442\u043d\u0435\u043d\u044c\u043a\u043e\u043c \u044d\u043d\u0442\u0435\u0440\u043f\u0440\u0430\u0439\u0437\u0435 \u0432\u044b \u043d\u0430\u0439\u0434\u0451\u0442\u0435 \u0441\u0432\u043e\u0438 \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0435 \u0411\u0414 \u0434\u043b\u044f \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>  <\/p>\n<p>\u041f\u0440\u0435\u0434\u043f\u043e\u043b\u0430\u0433\u0430\u0435\u0442\u0441\u044f \u0447\u0442\u043e \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u043d\u0438\u0436\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u044e\u0442\u0441\u044f \u0432 \u0434\u043e\u043c\u0430\u0448\u043d\u0435\u043c \u043a\u0430\u0442\u0430\u043b\u043e\u0433\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f. \u0421\u043a\u0430\u0447\u0438\u0432\u0430\u0435\u043c \u0430\u0440\u0445\u0438\u0432:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">curl -o StackOverflow2010.7z https:\/\/downloads.brentozar.com\/StackOverflow2010.7z<\/code><\/pre>\n<p>  <\/p>\n<p>\u0420\u0430\u0441\u043f\u0430\u043a\u043e\u0432\u044b\u0432\u0430\u0435\u043c (\u0432\u043e\u0442 \u0442\u0443\u0442-\u0442\u043e \u0438 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u043b\u0441\u044f \u043f\u0430\u043a\u0435\u0442 <code>p7zip<\/code> \u0438\u0437 EPEL):<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">7za x StackOverflow2010.7z<\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0444\u0430\u0439\u043b\u0438\u043a\u0438:<\/p>\n<p>  <\/p>\n<ul>\n<li>Readme_2010.txt \u2014 \u043d\u0430\u043c \u0431\u043e\u043b\u044c\u0448\u0435 \u043d\u0435 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f<\/li>\n<li>StackOverflow2010.mdf \u2014 \u0444\u0430\u0439\u043b \u0434\u0430\u043d\u043d\u044b\u0445<\/li>\n<li>StackOverflow2010_log.ldf \u2014 \u0444\u0430\u0439\u043b \u0436\u0443\u0440\u043d\u0430\u043b\u043e\u0432 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439<\/li>\n<\/ul>\n<p>  <\/p>\n<p>\u041d\u0430\u043f\u043e\u043c\u043d\u044e, \u0447\u0442\u043e \u0431\u0430\u0437\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 MS SQL Server \u0432\u0441\u0435\u0433\u0434\u0430 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u043d\u0435 \u043c\u0435\u043d\u044c\u0448\u0435, \u0447\u0435\u043c \u0438\u0437 \u0434\u0432\u0443\u0445 \u0444\u0430\u0439\u043b\u043e\u0432. \u0414\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043e\u0434\u0438\u043d \u0438\u043b\u0438 \u0431\u043e\u043b\u044c\u0448\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 \u0434\u0430\u043d\u043d\u044b\u0445: \u043f\u0435\u0440\u0432\u044b\u0439 \u043e\u0431\u044b\u0447\u043d\u043e \u0441 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435\u043c <code>mdf<\/code>, \u0432\u0442\u043e\u0440\u043e\u0439 \u0438 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0435 <code>ndf<\/code>, \u043d\u043e \u044d\u0442\u043e \u043b\u0438\u0448\u044c \u0441\u043e\u0433\u043b\u0430\u0448\u0435\u043d\u0438\u0435 \u2014 \u044d\u0442\u043e \u0444\u0430\u0439\u043b\u044b \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0445\u0440\u0430\u043d\u044f\u0442\u0441\u044f \u0434\u0430\u043d\u043d\u044b\u0435 \u0432 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0430\u0445 \u043f\u043e 8 \u041a\u0438\u0411. \u0418 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043e\u0434\u0438\u043d \u0438\u043b\u0438 \u0431\u043e\u043b\u044c\u0448\u0435 (\u0440\u0435\u0434\u043a\u043e-\u0440\u0435\u0434\u043a\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u043e\u0434\u043d\u043e\u0433\u043e) \u0444\u0430\u0439\u043b \u0441 \u0436\u0443\u0440\u043d\u0430\u043b\u0430\u043c\u0438 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439, \u043e\u0431\u044b\u0447\u043d\u043e \u0441 \u0440\u0430\u0441\u0448\u0438\u0440\u0435\u043d\u0438\u0435\u043c ldf. \u041e\u0431\u0430 \u0432\u0438\u0434\u0430 \u0444\u0430\u0439\u043b\u043e\u0432 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043e\u0431\u044f\u0437\u0430\u0442\u0435\u043b\u044c\u043d\u044b\u043c\u0438. \u0416\u0443\u0440\u043d\u0430\u043b\u044b \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439 \u2014 \u044d\u0442\u043e \u043d\u0435 &#171;\u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u043b\u043e\u0433\u0438&#187;, \u0430 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u044d\u043b\u0435\u043c\u0435\u043d\u0442 \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 \u0447\u0430\u0441\u0442\u043e \u0432\u0430\u0436\u043d\u044b\u0439 \u0444\u0430\u043a\u0442\u043e\u0440, \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0438\u0432\u0430\u044e\u0449\u0438\u0439 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c. \u0412 \u0434\u0440\u0443\u0433\u0438\u0445 \u0421\u0423\u0411\u0414 \u044d\u0442\u043e\u0442 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043d\u0430\u0437\u044b\u0432\u0430\u044e\u0442 WAL (write-ahead log). \u0414\u043b\u044f \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0434\u0430\u043d\u043d\u044b\u0445 WAL\/ldf \u0434\u0430\u0436\u0435 \u0432\u0430\u0436\u043d\u0435\u0435, \u0447\u0435\u043c \u0444\u0430\u0439\u043b\u044b \u0434\u0430\u043d\u043d\u044b\u0445, &#171;\u0432\u044b\u043a\u0438\u043d\u0443\u0442\u044c&#187; WAL\/ldf \u043d\u0435\u043b\u044c\u0437\u044f. \u0412\u0441\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438 \u0441 \u0444\u0430\u0439\u043b\u0430\u043c\u0438 \u0411\u0414 \u043d\u0443\u0436\u043d\u043e \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u0432 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0435 \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0438 \u043a\u043e\u043d\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u0438 \u0444\u0430\u0439\u043b\u043e\u0432 \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 \u0444\u0430\u0439\u043b\u043e\u0432 WAL. \u042f \u043f\u043e\u043d\u0438\u043c\u0430\u044e, \u0447\u0442\u043e \u044d\u0442\u043e \u0441\u043a\u0430\u0437\u0430\u043d\u043e \u0443\u0436\u0435 100500 \u0440\u0430\u0437, \u0438 \u0442\u0435, \u043a\u043e\u043c\u0443 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043d\u0443\u0436\u043d\u0430 \u044d\u0442\u0430 \u0441\u0442\u0430\u0442\u044c\u044f, \u0434\u043e\u043b\u0436\u043d\u044b (MUST \u0432 \u0442\u0435\u0440\u043c\u0438\u043d\u0430\u0445 <a href=\"https:\/\/www.rfc-editor.org\/rfc\/rfc2119\" rel=\"nofollow noopener noreferrer\">RFC-2119<\/a>) \u0437\u043d\u0430\u0442\u044c \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u0431\u0430\u0437\u043e\u0432\u044b\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b \u0440\u0430\u0431\u043e\u0442\u044b SQL Server, \u043d\u043e \u0432\u0441\u0451 \u0440\u0430\u0432\u043d\u043e, \u0441\u0447\u0438\u0442\u0430\u044e \u0432\u0430\u0436\u043d\u044b\u043c \u043d\u0430\u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0432 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043c\u044b \u0441\u043e\u0431\u0438\u0440\u0430\u0435\u043c\u0441\u044f \u043d\u0430\u043f\u0440\u044f\u043c\u0443\u044e \u043c\u0430\u043d\u0438\u043f\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0444\u0430\u0439\u043b\u0430\u043c\u0438.<\/p>\n<p>  <\/p>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u043c\u043d\u0435 \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u0443\u0434\u043e\u0431\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c &#171;\u0440\u043e\u0434\u043d\u043e\u0435&#187; \u0438\u043c\u044f \u0444\u0430\u0439\u043b\u043e\u0432, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0435\u0440\u0435\u0438\u043c\u0435\u043d\u0443\u044e:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\"># StackOverflow2010.mdf -> sof.mdf mv StackOverflow2010.mdf sof.mdf # StackOverflow2010_log.ldf -> sof_log.ldf mv StackOverflow2010_log.ldf sof_log.ldf<\/code><\/pre>\n<p>  <\/p>\n<p>\u0421\u043e\u0437\u0434\u0430\u0451\u043c \u043f\u0430\u043f\u043a\u0443 <code>\/var\/opt\/mssql\/data\/xfs\/template\/sof<\/code>, \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u0442\u0443\u0434\u0430 \u0444\u0430\u0439\u043b\u044b \u0438 \u0443\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u043c \u0432\u043b\u0430\u0434\u0435\u043b\u044c\u0446\u0435\u043c mssql:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo mkdir -p \/var\/opt\/mssql\/data\/xfs\/template\/sof sudo cp {sof.mdf,sof_log.ldf} \/var\/opt\/mssql\/data\/xfs\/template\/sof sudo chown -R mssql:mssql \/var\/opt\/mssql\/data\/xfs\/template\/sof<\/code><\/pre>\n<p>  <\/p>\n<p>\u042d\u0442\u0438 \u0431\u0435\u0441\u043a\u043e\u043d\u0435\u0447\u043d\u044b\u0435 <code>chown<\/code>-\u044b \u0431\u044b\u043b\u0438 \u0441\u0432\u044f\u0437\u0430\u043d\u044b \u0441 \u0442\u0435\u043c, \u0447\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u043c \u043c\u044b \u0438\u0437-\u043f\u043e\u0434 \u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f, \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u0447\u0435\u0440\u0435\u0437 sudo \u043e\u0442 \u0438\u043c\u0435\u043d\u0438 root, \u0430 SQL Server \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u043e\u0442 \u0438\u043c\u0435\u043d\u0438 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f mssql \u0438 \u043a\u0430\u0442\u0430\u043b\u043e\u0433 <code>\/var\/opt\/mssql\/data\/<\/code> \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0442\u043e\u043b\u044c\u043a\u043e \u0435\u043c\u0443. \u0414\u043b\u044f \u0442\u043e\u0433\u043e \u0447\u0442\u043e\u0431\u044b \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043f\u0440\u0430\u0432\u0430 \u0438 \u0432\u043b\u0430\u0434\u0435\u043b\u044c\u0446\u0430 \u0444\u0430\u0439\u043b\u043e\u0432 \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c <code>ls -l<\/code>, \u0438 \u0445\u043e\u0442\u044f \u0432 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0435 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0442\u0438\u0432\u043e\u0432 \u0434\u043b\u044f <code>ls -l<\/code> \u0435\u0441\u0442\u044c \u043a\u043e\u043c\u0430\u043d\u0434\u0430-\u0430\u043b\u0438\u0430\u0441 <code>ll<\/code>, \u043d\u043e \u0432 OL \u0442\u0430\u043a\u043e\u0439 \u0430\u043b\u0438\u0430\u0441 \u0435\u0441\u0442\u044c \u0443 &#171;\u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e&#187; \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f, \u043d\u043e \u043d\u0435\u0442 \u0443 root.<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo ls -la \/var\/opt\/mssql\/data\/xfs\/template\/sof<\/code><\/pre>\n<p>  <\/p>\n<p>\u0417\u0430\u043c\u0435\u0447\u0430\u0435\u043c, \u043a\u0441\u0442\u0430\u0442\u0438, \u0447\u0442\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043b\u0438\u0441\u044c \u0444\u0430\u0439\u043b\u044b \u043d\u0435\u0442\u043e\u0440\u043e\u043f\u043b\u0438\u0432\u043e, \u0441\u043e \u0441\u043a\u043e\u0440\u043e\u0441\u0442\u044c\u044e \u043e\u0431\u044b\u0447\u043d\u043e\u0433\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<p>  <\/p>\n<h3 id=\"delaem-bd-shablon-i-klony-bd\">\u0414\u0435\u043b\u0430\u0435\u043c \u0411\u0414-\u0448\u0430\u0431\u043b\u043e\u043d \u0438 \u043a\u043b\u043e\u043d\u044b \u0411\u0414<\/h3>\n<p>  <\/p>\n<p>\u0427\u0430\u0441\u0442\u044c \u0438\u043d\u0441\u0442\u0440\u0443\u043a\u0446\u0438\u0439 \u044d\u0442\u043e\u0433\u043e \u0440\u0430\u0437\u0434\u0435\u043b\u0430 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0435\u0442\u0441\u044f \u043d\u0430 \u0441\u0442\u043e\u0440\u043e\u043d\u0435 SQL Server. \u0415\u0441\u043b\u0438 \u0432\u044b \u0443\u043b\u044c\u0442\u0440\u0430-\u0444\u0430\u043d\u0430\u0442 CLI, \u0438 \u043f\u0440\u0438 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 SQL Server <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/linux\/quickstart-install-connect-red-hat?view=sql-server-ver16#tools\" rel=\"nofollow noopener noreferrer\">\u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0438<\/a> command-line tools, \u0442\u043e, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u0432\u044b \u0438 \u0434\u0430\u043b\u044c\u0448\u0435 \u043c\u043e\u0436\u0435\u0442\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0442\u043e\u043b\u044c\u043a\u043e \u0432 SSH-\u043a\u043e\u043d\u0441\u043e\u043b\u0438. \u041d\u0443 \u0430 \u043c\u044b, \u0438\u0437\u043d\u0435\u0436\u0435\u043d\u043d\u044b\u0435 \u043a\u043e\u043c\u0444\u043e\u0440\u0442\u043e\u043c, \u043e\u0442\u043a\u0440\u043e\u0435\u043c SSMS \u0438 \u0431\u0443\u0434\u0435\u043c \u0432\u044b\u043f\u043e\u043b\u043d\u044f\u0442\u044c \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0442\u0430\u043c.<\/p>\n<p>  <\/p>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u0411\u0414:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO CREATE DATABASE [template_xfs_sof] ON  ( FILENAME = N'\/var\/opt\/mssql\/data\/xfs\/template\/sof\/sof.mdf' ), ( FILENAME = N'\/var\/opt\/mssql\/data\/xfs\/template\/sof\/sof_log.ldf' ) FOR ATTACH GO<\/code><\/pre>\n<p>  <\/p>\n<p>\u0423 \u043c\u0435\u043d\u044f \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u0439 \u0411\u0414 \u0441 \u043a\u043e\u043d\u0432\u0435\u0440\u0442\u0430\u0446\u0438\u0435\u0439 \u0438\u0437 \u0441\u0442\u0430\u0440\u043e\u0433\u043e \u0444\u043e\u0440\u043c\u0430\u0442\u0430 \u0445\u0440\u0430\u043d\u0435\u043d\u0438\u044f \u0437\u0430\u043d\u044f\u043b\u043e 5 \u0441\u0435\u043a\u0443\u043d\u0434.<\/p>\n<p>  <\/p>\n<p>\u041d\u0430 \u043d\u0430\u0448\u0435\u043c \u0434\u0435\u043c\u043e-\u0441\u0442\u0435\u043d\u0434\u0435 \u043d\u0430 \u044d\u0442\u043e\u043c \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u0430 \u0432 \u043e\u0431\u0449\u0435\u043c-\u0442\u043e \u0437\u0430\u043a\u043e\u043d\u0447\u0435\u043d\u043e. \u0412 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0439 \u0436\u0438\u0437\u043d\u0438 \u0441\u0432\u0435\u0436\u0435\u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u0443\u044e \u0431\u0430\u0437\u0443, \u043f\u0440\u0438\u043d\u0435\u0441\u0451\u043d\u043d\u0443\u044e &#171;\u043e\u0442\u043a\u0443\u0434\u0430-\u0442\u043e&#187; \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0440\u0438\u0447\u0435\u0441\u0430\u0442\u044c. \u041c\u043e\u0436\u0435\u0442 \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u043e\u0431\u044a\u0435\u043a\u0442\u044b \u043f\u0435\u0440\u0435\u0441\u043e\u0437\u0434\u0430\u0442\u044c (\u0441\u0438\u043d\u043e\u043d\u0438\u043c\u044b \u0438\u043b\u0438 \u0425\u041f), \u043c\u043e\u0436\u0435\u0442 \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c, \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c \u043a\u0430\u043a\u0438\u0435-\u0442\u043e \u043c\u0438\u0433\u0440\u0430\u0446\u0438\u0438 \u0434\u043e &#171;\u043d\u0443\u0436\u043d\u043e\u0439&#187; \u0432\u0435\u0440\u0441\u0438\u0438, \u043f\u0435\u0440\u0435\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0440\u0435\u0436\u0438\u043c \u0441\u043e\u0432\u043c\u0435\u0441\u0442\u0438\u043c\u043e\u0441\u0442\u0438, \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u0442\u044c \u043c\u043e\u0434\u0435\u043b\u044c \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f. \u0422\u0430\u043a\u0438\u0435 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f, \u043a\u043e\u043d\u0435\u0447\u043d\u043e, \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u043d\u044b \u0438 \u0441\u0438\u043b\u044c\u043d\u043e \u0437\u0430\u0432\u0438\u0441\u044f\u0442 \u043e\u0442 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0439 \u0432\u0430\u0448\u0435\u0439 \u0411\u0414.<\/p>\n<p>  <\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0442\u043e\u0433\u043e \u043a\u0430\u043a \u0431\u0430\u0437\u0430 \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043b\u0435\u043d\u0430 \u043a \u043a\u043b\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044e, \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0438\u043c \u0435\u0451 \u0432 \u043e\u0444\u0444\u043b\u0430\u0439\u043d \u0440\u0435\u0436\u0438\u043c:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO ALTER DATABASE [template_xfs_sof] SET OFFLINE GO<\/code><\/pre>\n<p>  <\/p>\n<p>\u042d\u0442\u043e \u0432\u0430\u0436\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442. \u0412 Windows \u0444\u0430\u0439\u043b\u044b \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u0439 \u0411\u0414 SQL Server \u0434\u0430\u0436\u0435 \u0441 \u043f\u0440\u0430\u0432\u0430\u043c\u0438 \u0430\u0434\u043c\u0438\u043d\u0438\u0441\u0442\u0440\u0430\u0442\u043e\u0440\u0430 \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0431\u044b\u0447\u043d\u044b\u043c\u0438 \u0441\u0440\u0435\u0434\u0441\u0442\u0432\u0430\u043c\u0438. \u0410 \u0447\u0442\u043e\u0431\u044b \u0444\u0430\u0439\u043b\u044b \u0431\u044b\u043b\u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u044b, \u043d\u0443\u0436\u043d\u043e \u043b\u0438\u0431\u043e \u043f\u0435\u0440\u0435\u0432\u0435\u0441\u0442\u0438 \u0431\u0430\u0437\u0443 \u0432 offline (\u0435\u0451 \u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0430\u0446\u0438\u044f \u0432 master \u0441\u043e\u0445\u0440\u0430\u043d\u044f\u0435\u0442\u0441\u044f), \u043b\u0438\u0431\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0438\u0442\u044c detach, \u043b\u0438\u0431\u043e \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u0442\u044c \u0440\u0430\u0431\u043e\u0442\u0443 SQL Server. \u041f\u0435\u0440\u0435\u0432\u043e\u0434 \u0431\u0430\u0437\u044b \u0432 offline \u0432 \u044d\u0442\u043e\u043c \u0441\u043c\u044b\u0441\u043b\u0435 \u043d\u0430\u0438\u043c\u0435\u043d\u0435\u0435 &#171;\u0438\u043d\u0432\u0430\u0437\u0438\u0432\u043d\u044b\u0439&#187;. \u0412\u043f\u0440\u043e\u0447\u0435\u043c, \u0441 \u0442\u043e\u0447\u043a\u0438 \u0437\u0440\u0435\u043d\u0438\u044f \u0444\u0430\u0439\u043b\u043e\u0432 \u0411\u0414 \u044d\u0442\u043e \u0432\u0441\u0451 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0438\u0434\u0435\u043d\u0442\u0438\u0447\u043d\u0430\u044f \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430: \u0437\u0430\u0432\u0435\u0440\u0448\u0438\u0442\u044c \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f, \u043e\u0442\u043c\u0435\u043d\u0438\u0442\u044c \u043e\u0442\u043a\u0440\u044b\u0442\u044b\u0435 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0438, \u0441\u0431\u0440\u043e\u0441\u0438\u0442\u044c \u0433\u0440\u044f\u0437\u043d\u044b\u0435 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u044b \u0432 \u0444\u0430\u0439\u043b \u0434\u0430\u043d\u043d\u044b\u0445. \u041e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043e\u0442\u043c\u0435\u0447\u0443, \u0447\u0442\u043e \u043c\u043d\u043e\u0433\u0438\u0435 \u0432\u043d\u0435\u0448\u043d\u0438\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u0440\u0435\u0437\u0435\u0440\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f (\u0432\u043d\u0435\u0448\u043d\u0438\u0435 \u2014 \u0442\u043e \u0435\u0441\u0442\u044c \u043d\u0435 \u0441\u0430\u043c SQL Server) \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0441\u043d\u0438\u043c\u043a\u0430 \u0444\u0430\u0439\u043b\u043e\u0432 \u0432 Windows \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442 \u043e\u0441\u043e\u0431\u044b\u0439 Volume Shadow copy Service (VSS), \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043c\u0430\u043b\u043e \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0434\u043e\u0441\u0442\u0443\u043f \u043a \u044d\u0442\u0438\u043c \u0434\u0430\u043d\u043d\u044b\u043c, \u0442\u0430\u043a \u0435\u0449\u0435 \u0438 \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0438\u0432\u0430\u0435\u0442, \u0447\u0442\u043e\u0431\u044b \u0444\u0430\u0439\u043b\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0438 \u0436\u0443\u0440\u043d\u0430\u043b\u043e\u0432 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439 \u043f\u043e\u043b\u0443\u0447\u0430\u043b\u0438\u0441\u044c &#171;\u043d\u0430 \u043e\u0434\u0438\u043d \u043c\u043e\u043c\u0435\u043d\u0442&#187;, \u0447\u0442\u043e \u0432\u0430\u0436\u043d\u043e \u0434\u043b\u044f \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f. \u0415\u0441\u0442\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u044d\u0442\u043e \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u043a\u0438 VSS \u043e\u0442 SQL Server. \u041a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u043e \u2014 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0441\u0442\u0438 \u0432 <a href=\"https:\/\/learn.microsoft.com\/en-us\/sql\/relational-databases\/backup-restore\/sql-server-vss-writer-backup-guide\" rel=\"nofollow noopener noreferrer\">\u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438<\/a>.<\/p>\n<p>  <\/p>\n<p>\u041d\u043e \u0432 linux \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c root \u043d\u0435 \u043f\u0440\u043e\u0441\u0442\u043e &#171;\u0430\u0434\u043c\u0438\u043d\u0438\u0441\u0442\u0440\u0430\u0442\u043e\u0440&#187;. \u041e\u043d \u0447\u0430\u0441\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0434\u0430\u0436\u0435 \u0442\u043e, \u0447\u0442\u043e \u043d\u0435\u043b\u044c\u0437\u044f. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0447\u0438\u0442\u0430\u0442\u044c \u0438\u043b\u0438 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u044d\u043a\u0441\u043a\u043b\u044e\u0437\u0438\u0432\u043d\u043e \u0437\u0430\u0445\u0432\u0430\u0447\u0435\u043d\u043d\u044b\u0439 \u0444\u0430\u0439\u043b, \u0432 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0444\u0430\u0439\u043b\u044b \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0431\u043e\u0442\u044b. \u0410 \u0432\u043e\u0442 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0433\u0430\u0440\u0430\u043d\u0442\u0438\u0438, \u0447\u0442\u043e \u043f\u043e\u0442\u043e\u043c \u044d\u0442\u0438 \u0444\u0430\u0439\u043b\u044b \u043d\u0435 \u043c\u0443\u0441\u043e\u0440 \u2014 \u0442\u0443\u0442 \u0441\u043b\u043e\u0436\u043d\u0435\u0435. \u0412\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u0435\u0441\u043b\u0438 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0444\u0430\u0439\u043b\u044b \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443, \u0434\u0430\u0436\u0435 \u0435\u0441\u043b\u0438 \u0431\u044b \u044d\u0442\u043e \u0431\u044b\u043b\u0438 \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u044b\u0435 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0438, \u0430 \u044d\u0442\u043e \u043d\u0435 \u0432\u0441\u0435\u0433\u0434\u0430 \u0442\u0430\u043a, \u0442\u043e \u0444\u0430\u0439\u043b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u043e\u0432\u0430\u0442\u044c \u0436\u0443\u0440\u043d\u0430\u043b\u0443 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439. \u0410 \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u0437\u043d\u0430\u0447\u0438\u0442\u044c, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c 2 \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0438 \u043d\u0435\u043d\u0443\u0436\u043d\u044b\u0445 \u0444\u0430\u0439\u043b\u0430. \u0412\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u0437\u0430 \u043a\u043e\u043d\u0441\u0438\u0441\u0442\u0435\u043d\u0442\u043d\u043e\u0441\u0442\u044c \u0444\u0430\u0439\u043b\u043e\u0432 \u043e\u0442\u0432\u0435\u0447\u0430\u0435\u0442 SQL Server \u0438 \u043d\u0435 \u0441\u0442\u043e\u0438\u0442 \u0431\u0435\u0437 \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e\u0441\u0442\u0438 \u0435\u043c\u0443 \u043c\u0435\u0448\u0430\u0442\u044c. \u0414\u0430, \u0432\u0430\u043c \u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u0432\u0435\u0437\u0442\u0438 \u0438 \u0444\u0430\u0439\u043b\u044b \u043c\u043e\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0441\u043d\u043e\u0432\u0430. \u0410 \u043c\u043e\u0436\u0435\u0442 \u0438 \u043d\u0435 \u043f\u043e\u0432\u0435\u0437\u0442\u0438.<\/p>\n<p>  <\/p>\n<p>\u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u0435\u0441\u043b\u0438 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u0442\u0441\u044f \u0441\u043d\u043e\u0432\u0430 \u0432\u043d\u0435\u0441\u0442\u0438 \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0432 \u0448\u0430\u0431\u043b\u043e\u043d \u0431\u0430\u0437\u0443 \u0434\u0430\u043d\u043d\u044b\u0445 \u043c\u043e\u0436\u043d\u043e \u0441\u043d\u043e\u0432\u0430 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0438\u0442\u044c:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO ALTER DATABASE [template_xfs_sof] SET ONLINE GO<\/code><\/pre>\n<p>  <\/p>\n<p>\u041d\u0443 \u0438 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0441\u0430\u043c\u043e\u0435 \u0432\u043a\u0443\u0441\u043d\u043e\u0435. \u041a\u043e\u0433\u0434\u0430 \u0431\u0430\u0437\u0430 \u0432 \u0440\u0435\u0436\u0438\u043c\u0435 <code>OFFLINE<\/code> \u0432\u044b \u043c\u043e\u0436\u0435\u0442\u0435 \u043f\u0440\u043e\u0441\u0442\u043e &#171;\u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c&#187; \u0444\u0430\u0439\u043b\u044b \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u043c \u0441\u043d\u0438\u043c\u043a\u043e\u043c (\u0432 \u0440\u0430\u043c\u043a\u0430\u0445 \u043e\u0434\u043d\u043e\u0439 \u0444\u0430\u0439\u043b\u043e\u0432\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0442\u0430\u043a\u0443\u044e \u0444\u0443\u043d\u043a\u0446\u0438\u044e, \u043a\u043e\u043d\u0435\u0447\u043d\u043e):<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo cp --recursive --reflink=always --preserve=all \/var\/opt\/mssql\/data\/xfs\/template\/sof \/var\/opt\/mssql\/data\/xfs\/work\/sof1<\/code><\/pre>\n<p>  <\/p>\n<p>\u041a\u0440\u0430\u0442\u043a\u043e \u043f\u043e \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u0430\u043c:<\/p>\n<p>  <\/p>\n<ul>\n<li><code>--recursive<\/code> \u2014 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0430\u043f\u043a\u0443 \u0446\u0435\u043b\u0438\u043a\u043e\u043c \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u043e (\u043d\u043e \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u0442 \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u0444\u0430\u0439\u043b\u0443, \u043d\u0430\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u044f \u043f\u043e\u043d\u044f\u043b \u0432\u044b\u0432\u043e\u0434 <code>strace<\/code>)<\/li>\n<li><code>--reflink=always<\/code> \u2014 <strong>\u0442\u043e\u0442 \u0441\u0430\u043c\u044b\u0439<\/strong> &#171;\u0432\u043e\u043b\u0448\u0435\u0431\u043d\u044b\u0439&#187; \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u0437\u0430\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c &#171;\u0431\u0435\u0437 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f&#187;, \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u044f &#171;\u0441\u043d\u0438\u043c\u043e\u043a&#187; \u0438\u0441\u0445\u043e\u0434\u043d\u043e\u0433\u043e \u0444\u0430\u0439\u043b\u0430<\/li>\n<li><code>--preserve=all<\/code> \u2014 \u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u0440\u0430\u0432\u0430 \u0438 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u044b \u0444\u0430\u0439\u043b\u0430 (\u043d\u0443 \u043d\u0430\u043a\u043e\u043d\u0435\u0446-\u0442\u043e \u0431\u0435\u0437 \u0434\u0443\u0440\u0430\u0446\u043a\u043e\u0433\u043e <code>chown<\/code>!)<\/li>\n<li><code>\/var\/opt\/mssql\/data\/xfs\/template\/sof<\/code> \u2014 \u0447\u0442\u043e \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c<\/li>\n<li><code>\/var\/opt\/mssql\/data\/xfs\/work\/sof1<\/code> \u2014 \u043a\u0443\u0434\u0430 \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c<\/li>\n<\/ul>\n<p>  <\/p>\n<p>\u0417\u0430\u043c\u0435\u0447\u0430\u0435\u043c, \u0447\u0442\u043e \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043b\u043e\u0441\u044c \u0432\u0441\u0451 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u043e. \u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0432\u0441\u0451 \u043f\u0440\u043e\u0448\u043b\u043e, \u043a\u0430\u043a \u043e\u0436\u0438\u0434\u0430\u043b\u043e\u0441\u044c:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo ls -la \/var\/opt\/mssql\/data\/xfs\/work\/sof1<\/code><\/pre>\n<p>  <\/p>\n<p>\u041b\u044e\u0431\u0443\u0435\u043c\u0441\u044f \u0432\u044b\u0432\u043e\u0434\u043e\u043c:<\/p>\n<p>  <\/p>\n<pre><code class=\"plaintext\">drwxr-xr-x. 2 mssql mssql         40 Oct 13 06:18 . drwxr-xr-x. 3 mssql mssql         18 Oct 13 12:26 .. -rw-r--r--. 1 mssql mssql 9248833536 Oct 13 11:54 sof.mdf -rw-r--r--. 1 mssql mssql  268312576 Oct 13 11:54 sof_log.ldf<\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u0440\u0438\u0446\u0435\u043f\u043b\u044f\u0435\u043c \u0431\u0430\u0437\u0443 \u0434\u0430\u043d\u043d\u044b\u0445:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO CREATE DATABASE [work_xfs_sof_1] ON  ( FILENAME = N'\/var\/opt\/mssql\/data\/xfs\/work\/sof1\/sof.mdf' ), ( FILENAME = N'\/var\/opt\/mssql\/data\/xfs\/work\/sof1\/sof_log.ldf' ) FOR ATTACH GO<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412 \u043c\u043e\u0435\u0439 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0434\u0438\u043d \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c SQL Server (<code>sa<\/code>), \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043f\u0440\u0430\u0432\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u043c \u043c\u043d\u0435 \u043d\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u044b, \u0430 \u0432 \u0440\u0435\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0432\u0430\u043c \u0441\u043a\u043e\u0440\u0435\u0435 \u0432\u0441\u0435\u0433\u043e \u043f\u0440\u0438\u0434\u0451\u0442\u0441\u044f \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u043a\u0430\u043a\u043e\u0439-\u043d\u0438\u0431\u0443\u0434\u044c <code>sp_changedbowner<\/code> \u0438\/\u0438\u043b\u0438 \u0434\u0440\u0443\u0433\u0438\u0435 \u043c\u0430\u043d\u0438\u043f\u0443\u043b\u044f\u0446\u0438\u0438 \u0434\u043b\u044f \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0438 \u0441\u0442\u0435\u043d\u0434\u0430 \u043a \u0440\u0430\u0431\u043e\u0442\u0435. \u041d\u043e \u044d\u0442\u043e \u0432\u044b \u0443\u0436 \u0441\u0430\u043c\u0438 \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u0442\u0435\u0441\u044c.<\/p>\n<p>  <\/p>\n<p>\u0414\u043b\u044f \u0431\u043e\u043b\u044c\u0448\u0435\u0439 \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u043e\u0441\u0442\u0438 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0430 \u0434\u0435\u043b\u0430\u0435\u043c \u0435\u0449\u0435 \u043f\u0430\u0440\u0443 \u043a\u043e\u043f\u0438\u0439:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo cp --recursive --reflink=always --preserve=all \/var\/opt\/mssql\/data\/xfs\/template\/sof \/var\/opt\/mssql\/data\/xfs\/work\/sof2 sudo cp --recursive --reflink=always --preserve=all \/var\/opt\/mssql\/data\/xfs\/template\/sof \/var\/opt\/mssql\/data\/xfs\/work\/sof3<\/code><\/pre>\n<p>  <\/p>\n<p>\u0418 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u0444\u0430\u0439\u043b\u044b \u0432 \u0411\u0414 <code>[work_xfs_sof_2]<\/code> \u0438 <code>[work_xfs_sof_3]<\/code>.<\/p>\n<p>  <\/p>\n<p>\u0414\u0430\u043d\u043d\u044b\u0435 \u043e\u0442\u043b\u0438\u0447\u043d\u043e \u0447\u0438\u0442\u0430\u044e\u0442\u0441\u044f:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master];  SELECT * FROM [work_xfs_sof_1].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_xfs_sof_2].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_xfs_sof_3].[dbo].[Users] u WHERE u.Id = 4;<\/code><\/pre>\n<p>  <\/p>\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/tj\/vc\/vi\/tjvcviq3u644ensrlkzfcbbiydk.png\" alt=\"\u0432\u0441\u0451 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442!\" data-src=\"https:\/\/habrastorage.org\/webt\/tj\/vc\/vi\/tjvcviq3u644ensrlkzfcbbiydk.png\"\/><\/p>\n<p>  <\/p>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0434\u0430\u043d\u043d\u044b\u0435 \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e \u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">UPDATE [work_xfs_sof_1].[dbo].[Users] SET Reputation = Reputation + 1 WHERE Id = 4;  UPDATE [work_xfs_sof_2].[dbo].[Users] SET Reputation = Reputation + 2 WHERE Id = 4;  UPDATE [work_xfs_sof_3].[dbo].[Users] SET Reputation = Reputation + 3 WHERE Id = 4;   SELECT * FROM [work_xfs_sof_1].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_xfs_sof_2].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_xfs_sof_3].[dbo].[Users] u WHERE u.Id = 4;<\/code><\/pre>\n<p>  <\/p>\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/h7\/sf\/r5\/h7sfr5-tw-gh7lcaijsobsrt0xm.png\" alt=\"\u0438 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442!\" data-src=\"https:\/\/habrastorage.org\/webt\/h7\/sf\/r5\/h7sfr5-tw-gh7lcaijsobsrt0xm.png\"\/><\/p>\n<p>  <\/p>\n<p>\u0415\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043c\u043e\u043c\u0435\u043d\u0442, \u0447\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e\u0435 \u0441\u043b\u043e\u0436\u0435\u043d\u0438\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u0432 \u0444\u0430\u0439\u043b\u043e\u0432 \u0442\u0435\u043f\u0435\u0440\u044c \u043d\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442. \u0422\u043e \u0435\u0441\u0442\u044c \u0443 \u043a\u043e\u043c\u0430\u043d\u0434 <code>du<\/code> \u0438 <code>df<\/code> \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u0435\u0431\u0435\u0442 \u0441 \u043a\u0440\u0435\u0434\u0438\u0442\u043e\u043c \u043d\u0435 \u0441\u0432\u043e\u0434\u0438\u0442\u0441\u044f. \u0421\u0440\u0430\u0437\u0443 \u0441\u043a\u0430\u0436\u0443, \u0447\u0442\u043e \u043f\u0440\u044f\u043c-\u0442\u0430\u043a\u0438 \u0445\u043e\u0440\u043e\u0448\u0435\u0433\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u044f \u043d\u0435 \u0437\u043d\u0430\u044e. \u0412 \u044d\u0442\u043e\u0439 <a href=\"https:\/\/blogs.oracle.com\/linux\/post\/xfs-data-block-sharing-reflink\" rel=\"nofollow noopener noreferrer\">\u0441\u0442\u0430\u0442\u044c\u0435<\/a> \u0435\u0441\u0442\u044c \u043f\u0440\u0438\u043c\u0435\u0440, \u043a\u0430\u043a \u0434\u0435\u0442\u0430\u043b\u044c\u043d\u043e \u0430\u043d\u0430\u043b\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0442\u0430\u043a\u0438\u0435 \u0444\u0430\u0439\u043b\u044b \u043f\u0440\u0438 \u043f\u043e\u043c\u043e\u0449\u0438 <code>xfs_bmap<\/code>, \u043d\u043e \u043a\u0430\u043a-\u0442\u043e \u044d\u0442\u043e \u0445\u043b\u043e\u043f\u043e\u0442\u043d\u043e. \u0412 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 <code>df<\/code> \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0441\u0432\u043e\u0431\u043e\u0434\u043d\u043e\u0435 \u043c\u0435\u0441\u0442\u043e, \u043d\u0430 \u044d\u0442\u043e \u043c\u043e\u0436\u043d\u043e \u043e\u0440\u0438\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c\u0441\u044f.<\/p>\n<p>  <\/p>\n<h2 id=\"btrfs\">BTRFS<\/h2>\n<p>  <\/p>\n<p><a href=\"https:\/\/btrfs.wiki.kernel.org\/index.php\/Main_Page\" rel=\"nofollow noopener noreferrer\">BTRFS<\/a> \u0442\u043e\u0436\u0435 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0430\u044f \u0444\u0430\u0439\u043b\u043e\u0432\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430. \u041e\u043d\u0430 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u043c\u043e\u043b\u043e\u0434\u0430\u044f, \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u0441 2007 \u0433\u043e\u0434\u0430. CoW \u0443 \u043d\u0435\u0451 &#171;\u0432 \u043a\u0440\u043e\u0432\u0438&#187; \u2014 \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0438 \u044d\u0442\u043e \u043f\u043b\u044e\u0441, \u043d\u043e \u0432 \u0446\u0435\u043b\u043e\u043c \u044d\u0442\u043e \u043f\u043e\u0434\u043a\u043b\u0430\u0434\u044b\u0432\u0430\u0435\u0442 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0433\u0440\u0430\u0431\u043b\u0435\u0439 \u0432 \u0440\u0430\u0431\u043e\u0442\u0443 \u0441 \u043d\u0435\u0439. \u041f\u043b\u044e\u0441 \u044d\u0442\u043e \u0435\u0449\u0435 \u0438 \u0432\u0435\u0441\u044c\u043c\u0430 \u043c\u043d\u043e\u0433\u043e\u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u0430\u044f \u0424\u0421, \u043a\u0440\u043e\u043c\u0435 CoW, \u044d\u0442\u043e \u0435\u0449\u0451 \u0438 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 (subvolumes), \u044d\u0442\u043e \u043a\u043e\u043c\u043f\u0440\u0435\u0441\u0441\u0438\u044f \u043d\u0430 \u043b\u0435\u0442\u0443 (\u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0435 \u0432\u043a\u043b\u044e\u0447\u0430\u0439\u0442\u0435 \u0435\u0451 \u043d\u0430 \u0444\u0430\u0439\u043b\u0430\u0445 \u0411\u0414!), \u044d\u0442\u043e \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 RAID (\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0442\u043e\u0436\u0435 \u043d\u0430\u043c \u0441\u0435\u0439\u0447\u0430\u0441 \u043d\u0435 \u043d\u0443\u0436\u043d\u044b), \u0438 \u0435\u0449\u0435 \u0433\u043e\u0440\u0430 \u0432\u0441\u044f\u043a\u043e\u0433\u043e. \u0418\u0437\u0434\u0430\u043b\u0435\u043a\u0430 \u043f\u043e \u0444\u0438\u0447\u0430\u0441\u0442\u043e\u0441\u0442\u0438 \u043d\u0430\u043f\u043e\u043c\u0438\u043d\u0430\u0435\u0442 ZFS, \u043d\u043e \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0432\u0441\u0451 &#171;\u0441\u0430\u043c\u043e\u0431\u044b\u0442\u043d\u043e\u0435&#187;. \u041a\u043e\u0440\u043e\u0447\u0435, \u0441\u0432\u0438\u0441\u0442\u0435\u043b\u043a\u0438 \u0438 \u0433\u0443\u0434\u0435\u043b\u043a\u0438 \u043d\u0430 \u0432\u0441\u0435 \u0432\u043a\u0443\u0441\u044b \u2014 \u0438 \u0432\u0441\u0451 \u0435\u0449\u0435 \u0440\u0430\u0437\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0435 \u2014 \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u043b\u0443\u0447\u0448\u0435 \u043f\u043e\u043a\u0430 \u043d\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c, \u043f\u043e\u043a\u0430 \u043d\u0435 \u0443\u0442\u0440\u044f\u0441\u043b\u0438\u0441\u044c. \u0413\u0434\u0435-\u0442\u043e \u044d\u0442\u043e \u043a \u043c\u0435\u0441\u0442\u0443, \u0433\u0434\u0435-\u0442\u043e \u043c\u0435\u0448\u0430\u0435\u0442. \u041f\u043e\u043f\u0440\u043e\u0431\u0443\u0435\u043c \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f \u0445\u043e\u0442\u044f \u0431\u044b \u0441 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u043c\u0438 \u0441\u043d\u0438\u043c\u043a\u0430\u043c\u0438 \u043f\u043e\u0434\u0442\u043e\u043c\u043e\u0432.<\/p>\n<p>  <\/p>\n<h3 id=\"podtoma---likbez\">\u041f\u043e\u0434\u0442\u043e\u043c\u0430 \u2014 \u043b\u0438\u043a\u0431\u0435\u0437<\/h3>\n<p>  <\/p>\n<p>\u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 BTRFS \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0442\u0430\u043a\u0438\u043c \u0436\u0435 \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u043a\u0430\u043a \u0438 XFS \u2014 \u0432\u0441\u0451 \u0442\u043e\u0442 \u0436\u0435 <code>cp --reflink<\/code> \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c. \u041d\u043e \u0443 BTRFS \u0435\u0441\u0442\u044c \u043e\u0447\u0435\u043d\u044c \u0432\u0430\u0436\u043d\u0430\u044f \u0448\u0442\u0443\u043a\u0430 \u2014 \u043f\u043e\u0434\u0442\u043e\u043c\u0430. \u041e\u043d\u0438 \u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043a\u043b\u044e\u0447\u0435\u0432\u044b\u043c \u043f\u043e\u043d\u044f\u0442\u0438\u0435\u043c \u0434\u043b\u044f BTRFS \u0432 \u0447\u0430\u0441\u0442\u0438 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0438 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043d\u0438\u043c\u043a\u043e\u0432.<\/p>\n<p>  <\/p>\n<p><a href=\"https:\/\/btrfs.readthedocs.io\/en\/latest\/Subvolumes.html\" rel=\"nofollow noopener noreferrer\">\u041f\u043e\u0434\u0442\u043e\u043c<\/a> \u2014 \u044d\u0442\u043e \u0446\u0435\u043b\u043e\u0441\u0442\u043d\u043e\u0435 \u0438 \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0435 (\u0434\u043b\u044f \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043d\u0438\u043c\u043a\u043e\u0432) \u0434\u0435\u0440\u0435\u0432\u043e \u043f\u0430\u043f\u043e\u043a \u0438 \u0444\u0430\u0439\u043b\u043e\u0432. \u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u0444\u0430\u0439\u043b\u044b \u044d\u0442\u0438\u0445 \u0434\u0435\u0440\u0435\u0432\u044c\u0435\u0432 \u043b\u0435\u0436\u0430\u0442 \u0432\u043f\u0435\u0440\u0435\u043c\u0435\u0448\u043a\u0443 \u043d\u0430 \u043e\u0434\u043d\u043e\u043c \u0438 \u0442\u043e\u043c \u0436\u0435 \u0431\u043b\u043e\u0447\u043d\u043e\u043c \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u0432\u0435, \u0442\u0443\u0442 \u043d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u043c\u0430\u0433\u0438\u0438. \u0415\u0441\u043b\u0438 \u0433\u0434\u0435-\u0442\u043e \u0432\u043d\u0443\u0442\u0440\u0438 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 &#171;\u043d\u0430\u0445\u043e\u0434\u0438\u0442\u0441\u044f&#187; \u0434\u0440\u0443\u0433\u043e\u0439 \u043f\u043e\u0434\u0442\u043e\u043c, \u0442\u043e \u044d\u0442\u043e \u0447\u0435\u043c-\u0442\u043e \u043f\u043e\u0445\u043e\u0436\u0435 \u043d\u0430 \u043f\u0440\u0438\u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u0434\u0442\u043e\u043c \u2014 \u0432 \u0442\u043e\u043c \u0441\u043c\u044b\u0441\u043b\u0435, \u0447\u0442\u043e \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u043d\u0438\u043c\u043e\u043a &#171;\u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0433\u043e&#187; \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u0431\u0443\u0434\u0435\u0442 \u0441\u043e\u0434\u0435\u0440\u0436\u0430\u0442\u044c \u043b\u0438\u0448\u044c \u0441\u0441\u044b\u043b\u043a\u0443 \u043d\u0430 &#171;\u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439&#187;. \u0421\u0430\u043c\u043e\u0435 \u0432\u0430\u0436\u043d\u043e\u0435, \u0447\u0442\u043e \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u043c\u043e\u0436\u043d\u043e (\u043f\u043e\u0447\u0442\u0438) \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u043e \u0441\u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c. \u0418\u0441\u0442\u043e\u0440\u0438\u0447\u0435\u0441\u043a\u0438 \u0438\u0437 \u0440\u0430\u0441\u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0451\u043d\u043d\u044b\u0445 \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0442\u0438\u0432\u043e\u0432 \u043f\u0435\u0440\u0432\u044b\u043c \u043d\u0430\u0447\u0430\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c BTRFS \u0441 \u043f\u043e\u0434\u0442\u043e\u043c\u0430\u043c\u0438 OpenSUSE \u0434\u043b\u044f \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e\u0433\u043e &#171;\u0442\u043e\u0447\u043a\u0430\u043c \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f&#187; Windows. \u0427\u0430\u0449\u0435 \u0432\u0441\u0435\u0433\u043e \u044d\u0442\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a: \u0432 \u0424\u0421 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f 2 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 &#171;\u043d\u0438\u0436\u043d\u0435\u0433\u043e \u0443\u0440\u043e\u0432\u043d\u044f&#187; \u0434\u043b\u044f \u043a\u043e\u0440\u043d\u044f (\u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440 <code>\/@root<\/code>) \u0438 \u0434\u043b\u044f &#171;\u0445\u043e\u043c\u044f\u043a\u0430&#187; (\u043f\u0443\u0441\u0442\u044c <code>\/@home<\/code>). \u0422\u0430\u043a\u0436\u0435 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u043f\u0430\u043f\u043a\u0430 \u0434\u043b\u044f \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043d\u0438\u043c\u043a\u043e\u0432 \u043a\u043e\u0440\u043d\u044f, \u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0435 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u0434\u043b\u044f \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u0430 \u043f\u043e\u043f\u0430\u0434\u0430\u0442\u044c \u0432 \u0441\u043d\u0438\u043c\u043e\u043a (\u0432 \u041e\u0421 \u044d\u0442\u043e \u043e\u0431\u044b\u0447\u043d\u043e \u0433\u0434\u0435-\u0442\u043e \u0432 <code>\/var<\/code>, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0432 \u043d\u0430\u0448\u0435\u0439 \u0424\u0421 \u044d\u0442\u043e \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u0433\u0434\u0435-\u0442\u043e \u0432 <code>\/@root\/var\/...<\/code>). \u0412 fstab \u043c\u043e\u043d\u0442\u0438\u0440\u0443\u044e\u0442\u0441\u044f, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, <code>\/@root<\/code> \u0432 <code>\/<\/code> \u0438 <code>\/@home<\/code> \u0432 <code>\/home<\/code>. \u041f\u043e\u0441\u043b\u0435 \u044d\u0442\u043e\u0433\u043e \u043d\u0430 \u0441\u043e\u0431\u044b\u0442\u0438\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438 \u0438 \u0443\u0434\u0430\u043b\u0435\u043d\u0438\u044f \u043f\u0430\u043a\u0435\u0442\u043e\u0432 \u0432\u0435\u0448\u0430\u044e\u0442\u0441\u044f \u0445\u0443\u043a\u0438 \u0441 \u0432\u044b\u0437\u043e\u0432\u043e\u043c \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b (\u0447\u0430\u0441\u0442\u043e \u044d\u0442\u043e Timeshift \u0438\u043b\u0438 snapper) \u0438\u043b\u0438 \u0442\u0443\u043f\u043e \u0441\u0430\u043c\u043e\u043f\u0438\u0441\u043d\u044b\u0435 \u0441\u043a\u0440\u0438\u043f\u0442\u044b, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u0434\u0435\u043b\u0430\u044e\u0442 \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u043d\u0438\u043c\u043e\u043a \u043f\u0440\u0438 \u043a\u0430\u0436\u0434\u043e\u043c \u0442\u0430\u043a\u043e\u043c \u0441\u043e\u0431\u044b\u0442\u0438\u0438. \u041f\u0440\u0438\u0447\u0451\u043c \u044d\u0442\u043e\u0442 \u043f\u0443\u0442\u044c \u043f\u0440\u043e\u0442\u043e\u043f\u0442\u0430\u043d \u0432 \u0442\u043e\u0439 \u0438\u043b\u0438 \u0438\u043d\u043e\u0439 \u0441\u0442\u0435\u043f\u0435\u043d\u0438, \u043a\u0430\u0436\u0435\u0442\u0441\u044f, \u0443\u0436\u0435 \u0434\u043b\u044f \u0432\u0441\u0435\u0445 \u0440\u0430\u0441\u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0451\u043d\u043d\u044b\u0445 \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0442\u0438\u0432\u043e\u0432. \u041a\u043e\u043c\u0443 \u0438\u043d\u0442\u0435\u0440\u0435\u0441\u043d\u0430 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0430 \u0434\u043b\u044f ArchLinux, \u043f\u043e\u0440\u043e\u0439\u0442\u0435\u0441\u044c \u0432 \u0432\u0438\u0434\u0435\u043e Ermanno Ferrari \u043d\u0430 \u0435\u0433\u043e <a href=\"https:\/\/www.youtube.com\/c\/EFLinuxMadeSimple\" rel=\"nofollow noopener noreferrer\">\u043a\u0430\u043d\u0430\u043b\u0435<\/a> (\u043e\u043d, \u043f\u0440\u0430\u0432\u0434\u0430, \u0432\u0437\u044f\u043b \u043f\u0430\u0443\u0437\u0443 \u0432 \u0432\u044b\u043f\u0443\u0441\u043a\u0430\u0445 \u0432\u0438\u0434\u0435\u043e). \u0418\u043b\u0438 \u0432 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0435 &#171;\u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438&#187; OpenSUSE \u0438 \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u0438 \u043a \u044d\u0442\u043e\u043c\u0443, \u0445\u043c, \u0441\u0430\u043c\u043e\u0431\u044b\u0442\u043d\u043e\u043c\u0443 \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0442\u0438\u0432\u0443. \u042d\u0442\u043e\u0442 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043d\u0435 \u0437\u0430\u043c\u0435\u043d\u044f\u0435\u0442 \u0431\u044d\u043a\u0430\u043f\u043e\u0432, \u043a\u043e\u043d\u0435\u0447\u043d\u043e \u0436\u0435, \u043d\u043e \u043e\u0442\u043b\u0438\u0447\u043d\u043e \u0432\u044b\u0440\u0443\u0447\u0430\u0435\u0442 \u0432 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u043e\u0432 \u0441 \u041e\u0421.<\/p>\n<p>  <\/p>\n<p>\u0427\u0430\u0441\u0442\u043e \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043f\u043e\u0434\u0442\u043e\u043c\u043e\u0432 \u0438 \u0441\u043d\u0438\u043c\u043a\u043e\u0432 BTRFS \u0441\u0440\u0430\u0432\u043d\u0438\u0432\u0430\u044e\u0442 \u0441 &#171;\u043f\u043e\u0445\u043e\u0436\u0438\u043c\u0438&#187; \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430\u043c\u0438 LVM. \u041d\u0435 \u0431\u0443\u0434\u0443 \u0432\u0434\u0430\u0432\u0430\u0442\u044c\u0441\u044f \u0441\u0438\u043b\u044c\u043d\u043e \u0432 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e\u0441\u0442\u0438, \u043d\u043e &#171;\u044d\u0442\u043e \u0434\u0440\u0443\u0433\u043e\u0435&#187;: \u0424\u0421 \u0434\u0435\u043b\u0430\u0435\u0442 \u0441\u043d\u0438\u043c\u043a\u0438 \u043d\u0430 \u0443\u0440\u043e\u0432\u043d\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 \u0438 \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0438\u043c \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0431\u043b\u043e\u043a\u0430, \u043f\u043e\u0434\u0442\u043e\u043c \u043e\u0431\u044b\u0447\u043d\u043e \u043d\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d \u0432 \u0440\u0430\u0437\u043c\u0435\u0440\u0435 (\u0442\u043e\u043b\u044c\u043a\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0432\u0441\u0435\u0439 \u0424\u0421) \u0438 \u0441\u043d\u0438\u043c\u043a\u0438 \u0432 LVM \u0441\u043e\u0432\u0435\u0440\u0448\u0435\u043d\u043d\u043e \u043f\u043e-\u0434\u0440\u0443\u0433\u043e\u043c\u0443 \u0445\u0440\u0430\u043d\u044f\u0442 \u0440\u0430\u0437\u043d\u0438\u0446\u0443.<\/p>\n<p>  <\/p>\n<p>\u0415\u0449\u0435 \u0440\u0430\u0437 \u043e\u0431\u0440\u0430\u0449\u0443 \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435, \u0447\u0442\u043e BTRFS \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 CoW \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e, \u0447\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0440\u0443\u0448\u0438\u0442 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c \u0438\u043d\u0442\u0435\u043d\u0441\u0438\u0432\u043d\u043e\u0433\u043e \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0444\u0430\u0439\u043b\u043e\u0432 \u0438 \u0443\u0432\u0435\u043b\u0438\u0447\u0438\u0432\u0430\u0435\u0442 \u0444\u0440\u0430\u0433\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e (\u043e\u0431\u0440\u0430\u0437\u044b \u0412\u041c, \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445, \u0441\u043b\u043e\u0436\u043d\u044b\u0435 \u0431\u043e\u043b\u044c\u0448\u0438\u0435 \u0444\u0430\u0439\u043b\u044b) \u0438 \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0442\u0435 \u0444\u0430\u0439\u043b\u044b \u0438 \u043f\u0430\u043f\u043a\u0438, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0442\u0430\u043a \u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f, \u0441\u0442\u043e\u0438\u0442 \u043f\u043e\u043c\u0435\u0447\u0430\u0442\u044c \u0443\u043f\u043e\u043c\u044f\u043d\u0443\u0442\u044b\u043c <code>chattr +C \/dir\/file<\/code>. \u041f\u0440\u0438\u0447\u0451\u043c \u0430\u0442\u0440\u0438\u0431\u0443\u0442 \u044d\u0442\u043e\u0442 \u043d\u0430\u0434\u043e \u0441\u0442\u0430\u0432\u0438\u0442\u044c \u043d\u0430 \u0434\u0438\u0440\u0435\u043a\u0442\u043e\u0440\u0438\u044e \u0434\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0444\u0430\u0439\u043b\u043e\u0432 \u0438\u043b\u0438 \u043d\u0430 \u043f\u0443\u0441\u0442\u043e\u0439 \u0444\u0430\u0439\u043b (\u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043d\u0430 <a href=\"https:\/\/wiki.archlinux.org\/title\/btrfs\" rel=\"nofollow noopener noreferrer\">ArchWiki<\/a> \u2014 \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u043d\u0430 ArchWiki \u0432\u0435\u0441\u044c\u043c\u0430 \u043f\u043e\u043b\u0435\u0437\u043d\u043e\u0435 \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u043e\u0435 \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435). \u041e\u0442\u043c\u0435\u0447\u0443, \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u044d\u0442\u043e\u0433\u043e \u0444\u043b\u0430\u0433\u0430 \u043e\u0442\u043a\u043b\u044e\u0447\u0430\u0435\u0442 \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044c\u043d\u044b\u0445 \u0441\u0443\u043c\u043c \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e \u0444\u0430\u0439\u043b\u0430 \u0438 \u043c\u043e\u0436\u0435\u0442 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u043e\u0441\u0442\u044c \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439.<\/p>\n<p>  <\/p>\n<p>\u0414\u043b\u044f \u043d\u0430\u0441 \u0433\u043b\u0430\u0432\u043d\u0430\u044f \u043f\u0440\u0435\u043b\u0435\u0441\u0442\u044c \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c\u0430 \u043f\u043e\u0434\u0442\u043e\u043c\u043e\u0432 \u0438\u043c\u0435\u043d\u043d\u043e \u0432 \u043c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e\u043c \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0438 &#171;\u043a\u043e\u043f\u0438\u0438&#187; (snapshot) \u0432\u0441\u0435\u0433\u043e \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u0446\u0435\u043b\u0438\u043a\u043e\u043c. \u0412 \u043e\u0442\u043b\u0438\u0447\u0438\u0435 \u043e\u0442 <code>cp --reflink<\/code> \u044d\u0442\u043e \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043d\u0435 \u043f\u043e \u043e\u0434\u043d\u043e\u043c\u0443 \u0444\u0430\u0439\u043b\u0438\u043a\u0443, \u0430 \u0434\u043b\u044f \u0432\u0441\u0435\u0433\u043e \u043f\u043e\u0434\u0442\u043e\u043c\u0430. \u0414\u043b\u044f \u043e\u0434\u043d\u043e\u0439 \u0411\u0414 \u0438\u0437 \u0434\u0432\u0443\u0445 \u0444\u0430\u0439\u043b\u043e\u0432 \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u043d\u0435 \u043e\u0441\u043e\u0431\u043e \u043a\u0440\u0438\u0442\u0438\u0447\u043d\u0430, \u043d\u043e \u0435\u0441\u043b\u0438 \u043f\u043e\u0434\u0442\u043e\u043c \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u043c\u043d\u043e\u0433\u043e \u0444\u0430\u0439\u043b\u043e\u0432, \u0442\u043e \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u0430. \u0421\u043d\u0438\u043c\u043a\u0438 (snapshot) \u0431\u044b\u0432\u0430\u044e\u0442 \u043a\u0430\u043a \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0435 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0447\u0442\u0435\u043d\u0438\u044f, \u0442\u0430\u043a \u0438 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0435 \u043d\u0430 \u0447\u0442\u0435\u043d\u0438\u0435-\u0437\u0430\u043f\u0438\u0441\u044c \u2014 \u043d\u0430\u043c \u043d\u0443\u0436\u043d\u044b \u0432\u0442\u043e\u0440\u044b\u0435, \u043a\u043e\u043d\u0435\u0447\u043d\u043e. \u0421\u043d\u0438\u043c\u043a\u0438 \u043d\u0435 \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0435 \u2014 \u0435\u0441\u043b\u0438 \u0441\u043e\u0437\u0434\u0430\u0451\u0442\u0441\u044f \u0441\u043d\u0438\u043c\u043e\u043a \u043f\u043e\u0434\u0442\u043e\u043c\u0430, \u0432 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u0432\u043d\u0443\u0442\u0440\u0438 \u0435\u0441\u0442\u044c \u043f\u043e\u0434\u0442\u043e\u043c\u0430, \u0442\u043e \u0432\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0435 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u043d\u0435 \u0434\u0443\u0431\u043b\u0438\u0440\u0443\u044e\u0442\u0441\u044f. &#171;\u041c\u0433\u043d\u043e\u0432\u0435\u043d\u043d\u043e\u0441\u0442\u044c&#187; \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u043d\u0438\u043c\u043a\u043e\u0432 <a href=\"https:\/\/btrfs.readthedocs.io\/en\/latest\/btrfs-subvolume.html#performance\" rel=\"nofollow noopener noreferrer\">\u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0430<\/a> \u0442\u0435\u043c, \u0447\u0442\u043e \u043f\u0435\u0440\u0435\u0434 \u0435\u0433\u043e \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435\u043c \u0424\u0421 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0443\u0436\u0435 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u043d\u044b\u0445 \u043e\u0442\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0445 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439 \u0437\u0430\u043f\u0438\u0441\u0438.<\/p>\n<p>  <\/p>\n<p>\u041e\u043c\u0440\u0430\u0447\u0430\u0435\u0442 \u0432\u0441\u0451 \u044d\u0442\u043e \u0442\u043e\u043b\u044c\u043a\u043e \u0442\u043e, \u0447\u0442\u043e Microsoft \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e BTRFS \u043d\u0435 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u2014 \u0435\u0441\u043b\u0438 \u0432\u044b \u0441\u0442\u043e\u043b\u043a\u043d\u0451\u0442\u0435\u0441\u044c \u0441 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u043c\u0438, \u0432\u0435\u043d\u0434\u043e\u0440 \u0432\u0430\u043c \u043d\u0435 \u043f\u043e\u043c\u043e\u0436\u0435\u0442 (\u043e\u0445, \u0433\u043e\u0440\u0435-\u0433\u043e\u0440\u0435 \u0434\u043b\u044f \u0441\u0442\u0435\u043d\u0434\u0430 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438).<\/p>\n<p>  <\/p>\n<h3 id=\"podgotovka-razdela-1\">\u041f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0430 \u0440\u0430\u0437\u0434\u0435\u043b\u0430<\/h3>\n<p>  <\/p>\n<p>\u041d\u0430 \u044d\u0442\u043e\u0442 \u0440\u0430\u0437 \u043d\u0430\u0448\u0435 \u0441\u044b\u0440\u043e\u0435 \u0431\u043b\u043e\u0447\u043d\u043e\u0435 \u0443\u0441\u0442\u0440\u043e\u0439\u0441\u0442\u043e <code>sd\u0441<\/code>. \u0420\u0430\u0437\u043c\u0435\u0447\u0430\u0442\u044c \u0431\u0443\u0434\u0435\u043c \u043f\u0440\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u0442\u0430\u043a\u0436\u0435, \u043a\u0430\u043a \u0438 XFS:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo parted --script \/dev\/sd\u0441 -- \\     unit MiB \\     mklabel gpt \\     mkpart primary btrfs 1MiB 24GiB \\     name 1 sqlbtrfs \\     print<\/code><\/pre>\n<p>  <\/p>\n<p>\u041a\u043b\u044e\u0447\u0438 \u0442\u0435 \u0436\u0435, \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u0442\u0435 \u0436\u0435. \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0424\u0421:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo mkfs.btrfs \/dev\/sd\u04411 --force --label sqlbtrfs<\/code><\/pre>\n<p>  <\/p>\n<p>\u041c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u043c \u0434\u043b\u044f \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u044f \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo mkdir \/tmp\/mnt\/btrfs sudo mount \/dev\/sd\u04411 -o subvolid=0, noatime \/tmp\/mnt\/btrfs<\/code><\/pre>\n<p>  <\/p>\n<p>\u041a\u043b\u044e\u0447 <code>-o subvolid=0<\/code> \u043d\u0443\u0436\u0435\u043d \u043a\u0430\u043a \u0440\u0430\u0437, \u0447\u0442\u043e\u0431\u044b \u043f\u0440\u0438\u0446\u0435\u043f\u0438\u0442\u044c &#171;\u0441\u0430\u043c\u044b\u0439 \u043a\u043e\u0440\u043d\u0435\u0432\u043e\u0439&#187; \u0440\u0430\u0437\u0434\u0435\u043b.<\/p>\n<p>  <\/p>\n<p>\u0421\u043e\u0437\u0434\u0430\u0451\u043c \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u0443:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo btrfs subvolume create \/tmp\/mnt\/btrfs\/data sudo btrfs subvolume create \/tmp\/mnt\/btrfs\/data\/template sudo btrfs subvolume create \/tmp\/mnt\/btrfs\/data\/work<\/code><\/pre>\n<p>  <\/p>\n<p>\u0422\u0443\u0442 \u044f \u0441\u043e\u0437\u0434\u0430\u043b \u043f\u043e\u0434\u0442\u043e\u043c <code>data<\/code>, \u0437\u0430\u0442\u0435\u043c &#171;\u043a\u0430\u043a \u0431\u044b \u0432 \u043d\u0451\u043c&#187; (\u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0441\u0447\u0438\u0442\u0430\u0439\u0442\u0435 \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e \u0442\u043e\u0447\u043a\u043e\u0439 \u043c\u043e\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f) \u043f\u043e\u0434\u0442\u043e\u043c\u0430 <code>template<\/code> \u0438 <code>work<\/code>. \u041f\u0440\u0438 \u044d\u0442\u043e\u043c \u0434\u0430\u043b\u044c\u0448\u0435 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u0442\u044c \u0435\u0449\u0435 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u043f\u043e\u0434 \u043a\u0430\u0436\u0434\u0443\u044e \u0411\u0414, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u043c\u043e\u0433\u043b\u0438 \u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c \u0438 \u043f\u0440\u043e\u0441\u0442\u043e \u0434\u0438\u0440\u0435\u043a\u0442\u043e\u0440\u0438\u044f\u043c\u0438, \u043d\u043e \u043c\u043d\u0435 \u0442\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u0435\u0435.<\/p>\n<p>  <\/p>\n<p>\u041d\u0430\u0437\u043d\u0430\u0447\u0430\u0435\u043c \u043f\u043e\u0434\u0442\u043e\u043c \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo btrfs subvolume set-default \/tmp\/mnt\/btrfs\/data\/<\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u043e\u0434\u0442\u043e\u043c \u043f\u043e \u0443\u043c\u043e\u043b\u0447\u0430\u043d\u0438\u044e \u043c\u044b \u043d\u0430\u0437\u043d\u0430\u0447\u0438\u043b\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u0434\u043b\u044f \u0442\u043e\u0433\u043e, \u0447\u0442\u043e\u0431\u044b \u043d\u0435 \u0443\u043a\u0430\u0437\u044b\u0432\u0430\u0442\u044c \u0435\u0433\u043e \u0432 fstab.<\/p>\n<p>  <\/p>\n<p>\u0420\u0430\u0437\u043c\u043e\u043d\u0442\u0438\u0440\u0443\u0435\u043c:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo umount \/tmp\/mnt\/btrfs<\/code><\/pre>\n<p>  <\/p>\n<p>\u0421\u043e\u0437\u0434\u0430\u0451\u043c \u043f\u0430\u043f\u043a\u0443 <code>\/var\/opt\/mssql\/data\/btrfs<\/code> \u0438 \u043f\u0440\u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c \u0432 fstab \u043f\u043e UUID:<\/p>\n<p>  <\/p>\n<pre><code class=\"plaintext\"># ... \u0432 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0439 \u0441\u0442\u0440\u043e\u0447\u043a\u0435 \u0447\u0442\u043e-\u0442\u043e \u0442\u0430\u043a\u043e\u0435 UUID=cdd007bb-938d-4d6c-88e6-1cf28e7b84d8 \/var\/opt\/mssql\/data\/btrfs btrfs   defaults,noatime   0  0<\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u0435\u0440\u0435\u0433\u0440\u0443\u0436\u0430\u0435\u043c\u0441\u044f, \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0432 <code>\/var\/opt\/mssql\/data\/btrfs<\/code> \u043f\u043e\u044f\u0432\u0438\u043b\u0438\u0441\u044c <code>template<\/code> \u0438 <code>work<\/code> \u0438 \u0441\u043c\u043e\u0442\u0440\u0438\u043c, \u0447\u0442\u043e \u0432\u0441\u0435 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u043d\u0430 \u043c\u0435\u0441\u0442\u0435:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo btrfs subvolume list \/var\/opt\/mssql\/data\/btrfs\/<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u044b\u0432\u043e\u0434 \u043f\u0440\u0438\u043c\u0435\u0440\u043d\u043e \u0442\u0430\u043a\u043e\u0439 (ID \u043c\u043e\u0433\u0443\u0442 \u043e\u0442\u043b\u0438\u0447\u0430\u0442\u044c\u0441\u044f):<\/p>\n<p>  <\/p>\n<pre><code class=\"plaintext\">ID 257 gen 30 top level 5 path data ID 258 gen 470 top level 257 path template ID 259 gen 358 top level 257 path work<\/code><\/pre>\n<p>  <\/p>\n<p>\u041d\u0430\u043f\u043e\u0441\u043b\u0435\u0434\u043e\u043a \u043c\u0435\u043d\u044f\u0435\u043c \u0432\u043b\u0430\u0434\u0435\u043b\u044c\u0446\u0430:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo chown -R mssql:mssql \/var\/opt\/mssql\/data\/btrfs<\/code><\/pre>\n<p>  <\/p>\n<h3 id=\"sozdanie-faylov-bd-i-podtoma-dlya-razmnozheniya\">\u0421\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 \u0411\u0414 \u0438 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u0434\u043b\u044f &#171;\u0440\u0430\u0437\u043c\u043d\u043e\u0436\u0435\u043d\u0438\u044f&#187;<\/h3>\n<p>  <\/p>\n<p>\u0421\u0447\u0438\u0442\u0430\u0435\u043c, \u0447\u0442\u043e \u0444\u0430\u0439\u043b\u044b \u0431\u0430\u0437\u044b \u0434\u043b\u044f \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0443 \u043d\u0430\u0441 \u0443\u0436\u0435 \u0435\u0441\u0442\u044c (\u0441\u043c. \u0432\u044b\u0448\u0435 \u0432 \u0440\u0430\u0437\u0434\u0435\u043b\u0435 \u043f\u0440\u043e XFS). \u0421\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u043f\u043e\u0434\u0442\u043e\u043c \u0434\u043b\u044f \u044d\u0442\u043e\u0439 \u0431\u0430\u0437\u044b, \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b\u044b, \u043d\u0430\u0437\u043d\u0430\u0447\u0438\u043c \u0432\u043b\u0430\u0434\u0435\u043b\u044c\u0446\u0430:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\"># \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435 \u043f\u043e\u0434\u0442\u043e\u043c\u0430 sudo btrfs subvolume create \/var\/opt\/mssql\/data\/btrfs\/template\/sof # \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430, \u0437\u0430\u043f\u0440\u0435\u0449\u0430\u044e\u0449\u0435\u0433\u043e CoW sudo chattr +C \/var\/opt\/mssql\/data\/btrfs\/template\/sof # \u043a\u043e\u043f\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b\u044b sudo cp {sof.mdf,sof_log.ldf} \/var\/opt\/mssql\/data\/btrfs\/template\/sof # \u043e\u0442\u0434\u0430\u0451\u043c \u0432\u0441\u0451 mssql sudo chown -R mssql:mssql \/var\/opt\/mssql\/data\/btrfs\/template\/sof<\/code><\/pre>\n<p>  <\/p>\n<p>\u041d\u0435\u0441\u043c\u043e\u0442\u0440\u044f \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u043c\u044b \u043f\u043e\u0441\u0442\u0430\u0432\u0438\u043b\u0438 \u0430\u0442\u0440\u0438\u0431\u0443\u0442, \u0437\u0430\u043f\u0440\u0435\u0449\u0430\u044e\u0449\u0438\u0439 CoW, \u043c\u0435\u0445\u0430\u043d\u0438\u0437\u043c \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043d\u0438\u043c\u043a\u043e\u0432 \u0431\u0443\u0434\u0435\u0442 \u043d\u043e\u0440\u043c\u0430\u043b\u044c\u043d\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c. \u041f\u0440\u043e\u0441\u0442\u043e \u0435\u0441\u043b\u0438 \u0434\u0430\u043d\u043d\u044b\u0435 \u0444\u0430\u0439\u043b\u0430 \u0435\u0441\u0442\u044c \u043b\u0438\u0448\u044c \u0432 \u043e\u0434\u043d\u043e\u043c \u043f\u043e\u0434\u0442\u043e\u043c\u0435, \u0442\u043e CoW \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c\u0441\u044f. \u041f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0430\u0442\u0440\u0438\u0431\u0443\u0442\u0430 <code>\u0421<\/code> \u043c\u043e\u0436\u043d\u043e \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 <code>lsattr<\/code>:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo lsattr \/var\/opt\/mssql\/data\/btrfs\/template\/sof<\/code><\/pre>\n<p>  <\/p>\n<p>\u0411\u0430\u0437\u0443 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u0442\u043e\u0447\u043d\u043e \u0442\u0430\u043a\u0436\u0435, \u043a\u0430\u043a \u0432 \u0441\u043b\u0443\u0447\u0430\u0435 XFS:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO CREATE DATABASE [template_btrfs_sof] ON  ( FILENAME = N'\/var\/opt\/mssql\/data\/btrfs\/template\/sof\/sof.mdf' ), ( FILENAME = N'\/var\/opt\/mssql\/data\/btrfs\/template\/sof\/sof_log.ldf' ) FOR ATTACH GO<\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u044f, \u043a\u0430\u043a-\u0442\u043e \u0433\u043e\u0442\u043e\u0432\u0438\u043c \u0411\u0414 \u0438 \u0437\u0430\u0442\u0435\u043c \u043e\u0442\u043f\u0443\u0441\u043a\u0430\u043c \u0444\u0430\u0439\u043b\u044b:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO ALTER DATABASE [template_btrfs_sof] SET OFFLINE GO<\/code><\/pre>\n<p>  <\/p>\n<h3 id=\"klonirovanie-i-ispolzovanie-klonov\">\u041a\u043b\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u043a\u043b\u043e\u043d\u043e\u0432<\/h3>\n<p>  <\/p>\n<p>\u0421\u043e\u0437\u0434\u0430\u0442\u044c \u043c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u043d\u0438\u043c\u043e\u043a \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u043f\u0440\u043e\u0441\u0442\u043e:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo btrfs subvolume snapshot \/var\/opt\/mssql\/data\/btrfs\/template\/sof \/var\/opt\/mssql\/data\/btrfs\/work\/sof1 <\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u0440\u0430\u0432\u0430 mssql \u0432\u044b\u0434\u0430\u043b\u0438\u0441\u044c \u0441\u0430\u043c\u0438.<\/p>\n<p>  <\/p>\n<p>\u0410\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e XFS \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c \u0435\u0449\u0435 2 \u0441\u043d\u0438\u043c\u043a\u0430:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo btrfs subvolume snapshot \/var\/opt\/mssql\/data\/btrfs\/template\/sof \/var\/opt\/mssql\/data\/btrfs\/work\/sof2  sudo btrfs subvolume snapshot \/var\/opt\/mssql\/data\/btrfs\/template\/sof \/var\/opt\/mssql\/data\/btrfs\/work\/sof3 <\/code><\/pre>\n<p>  <\/p>\n<p>\u041f\u043e\u0434\u043a\u043b\u044e\u0447\u0430\u0435\u043c \u043f\u0435\u0440\u0432\u0443\u044e \u0411\u0414:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master] GO CREATE DATABASE [work_btrfs_sof_1] ON  ( FILENAME = N'\/var\/opt\/mssql\/data\/btrfs\/work\/sof1\/sof.mdf' ), ( FILENAME = N'\/var\/opt\/mssql\/data\/btrfs\/work\/sof1\/sof_log.ldf' ) FOR ATTACH GO<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u0442\u043e\u0440\u0443\u044e \u0438 \u0442\u0440\u0435\u0442\u044c\u044e \u0430\u043d\u0430\u043b\u043e\u0433\u0438\u0447\u043d\u043e \u0432 <code>work_btrfs_sof_2<\/code> <code>work_btrfs_sof_3<\/code>.<br \/>  \u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0447\u0442\u0435\u043d\u0438\u0435 \u0434\u0430\u043d\u043d\u044b\u0445:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master];  SELECT * FROM [work_btrfs_sof_1].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_btrfs_sof_2].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_btrfs_sof_3].[dbo].[Users] u WHERE u.Id = 4;<\/code><\/pre>\n<p>  <\/p>\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/dz\/x-\/cu\/dzx-cu3k-bhtqdhlijad6bhyjw0.png\" alt=\"\u0432\u0441\u0451 \u041e\u041a\" data-src=\"https:\/\/habrastorage.org\/webt\/dz\/x-\/cu\/dzx-cu3k-bhtqdhlijad6bhyjw0.png\"\/><\/p>\n<p>  <\/p>\n<p>\u0418 \u043c\u043e\u0434\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044e:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">UPDATE [work_btrfs_sof_1].[dbo].[Users] SET Reputation = Reputation + 1 WHERE Id = 4;  UPDATE [work_btrfs_sof_2].[dbo].[Users] SET Reputation = Reputation + 2 WHERE Id = 4;  UPDATE [work_btrfs_sof_3].[dbo].[Users] SET Reputation = Reputation + 3 WHERE Id = 4;   SELECT * FROM [work_btrfs_sof_1].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_btrfs_sof_2].[dbo].[Users] u WHERE u.Id = 4; SELECT * FROM [work_btrfs_sof_3].[dbo].[Users] u WHERE u.Id = 4;<\/code><\/pre>\n<p>  <\/p>\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/webt\/tz\/wg\/ea\/tzwgeam2wjqy1ochy2apuoqlljw.png\" alt=\"\u0432\u0441\u0451 \u043e\u0436\u0438\u0434\u0430\u0435\u043c\u043e\" data-src=\"https:\/\/habrastorage.org\/webt\/tz\/wg\/ea\/tzwgeam2wjqy1ochy2apuoqlljw.png\"\/><\/p>\n<p>  <\/p>\n<p>\u041d\u043e \u0442\u0435\u043f\u0435\u0440\u044c, \u0432 \u043e\u0442\u043b\u0438\u0447\u0438\u0435 \u043e\u0442 XFS, \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0434\u0438\u0441\u043a\u043e\u0432:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\">sudo btrfs filesystem du \/var\/opt\/mssql\/data\/btrfs<\/code><\/pre>\n<p>  <\/p>\n<p>\u041d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043d\u0430\u0433\u043b\u044f\u0434\u043d\u0435\u0435, \u0447\u0435\u043c \u0432 XFS, \u0445\u043e\u0442\u044f \u0442\u043e\u0436\u0435 &#171;\u0435\u0441\u0442\u044c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u043e \u0434\u043b\u044f \u0443\u043b\u0443\u0447\u0448\u0435\u043d\u0438\u044f&#187;:<\/p>\n<p>  <\/p>\n<pre><code class=\"plaintext\">     Total   Exclusive  Set shared  Filename    8.61GiB       0.00B           -  \/var\/opt\/mssql\/data\/btrfs\/template\/sof\/sof.mdf  255.88MiB       0.00B           -  \/var\/opt\/mssql\/data\/btrfs\/template\/sof\/sof_log.ldf    8.86GiB       0.00B           -  \/var\/opt\/mssql\/data\/btrfs\/template\/sof    8.86GiB       0.00B           -  \/var\/opt\/mssql\/data\/btrfs\/template    8.61GiB    56.00KiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof1\/sof.mdf  255.88MiB    67.76MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof1\/sof_log.ldf    8.86GiB    67.82MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof1    8.61GiB    56.00KiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof2\/sof.mdf  255.88MiB    67.76MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof2\/sof_log.ldf    8.86GiB    67.82MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof2    8.61GiB    56.00KiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof3\/sof.mdf  255.88MiB    67.76MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof3\/sof_log.ldf    8.86GiB    67.82MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work\/sof3   26.59GiB   203.45MiB           -  \/var\/opt\/mssql\/data\/btrfs\/work   35.45GiB   203.45MiB     8.86GiB  \/var\/opt\/mssql\/data\/btrfs<\/code><\/pre>\n<p>  <\/p>\n<p>\u0422\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043d\u0430 <code>btrfs filesystem df<\/code>, <code>btrfs filesystem usage<\/code> \u0438 \u0432\u043e\u043e\u0431\u0449\u0435 \u043f\u043e\u0447\u0438\u0442\u0430\u0442\u044c \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044e btrfs.<\/p>\n<p>  <\/p>\n<p>\u0410 \u0435\u0449\u0451 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043f\u0440\u043e\u0431\u043e\u0432\u0430\u0442\u044c \u0434\u0435\u043b\u0430\u0442\u044c \u0441\u043d\u0438\u043c\u043a\u0438 \u043f\u0440\u044f\u043c\u043e \u0432\u043e \u0432\u0440\u0435\u043c\u044f \u0440\u0430\u0431\u043e\u0442\u044b! \u0422\u0435\u043f\u0435\u0440\u044c \u0443 \u043d\u0430\u0441 \u043d\u0435\u0442 (\u043f\u043e \u043a\u0440\u0430\u0439\u043d\u0435\u0439 \u043c\u0435\u0440\u0435 \u043d\u0435 \u0434\u043e\u043b\u0436\u043d\u043e \u0431\u044b\u0442\u044c) \u043d\u0435\u0430\u0442\u043e\u043c\u0430\u0440\u043d\u043e\u0441\u0442\u0438 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0444\u0430\u0439\u043b\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 (<code>mdf<\/code>) \u0438 \u0436\u0443\u0440\u043d\u0430\u043b\u0430 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439 (<code>ldf<\/code>), \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0432 \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u0435 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0444\u0430\u0439\u043b\u043e\u0432 &#171;\u0433\u043e\u0440\u044f\u0447\u0435\u0439&#187; \u043a\u043e\u043f\u0438\u0438 \u0434\u043e\u043b\u0436\u043d\u043e \u043f\u0440\u043e\u0439\u0442\u0438 \u0443\u0441\u043f\u0435\u0448\u043d\u043e. \u041f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u043d\u0430 \u0431\u0430\u0437\u0435 <code>[work_btrfs_sof_1]<\/code> \u0438\u0434\u0451\u0442 \u0443 \u043d\u0430\u0441 \u043c\u043d\u043e\u0433\u043e\u0447\u0430\u0441\u043e\u0432\u043e\u0439 \u043c\u043d\u043e\u0433\u043e\u044d\u0442\u0430\u043f\u043d\u044b\u0439 \u0442\u0435\u0441\u0442 \u2014 \u0445\u043e\u0447\u0435\u0442\u0441\u044f, \u0447\u0442\u043e\u0431\u044b \u043a \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u044f\u043c \u043c\u043e\u0436\u043d\u043e \u0431\u044b\u043b\u043e \u0432\u0435\u0440\u043d\u0443\u0442\u044c\u0441\u044f \u0432\u043f\u043e\u0441\u043b\u0435\u0434\u0441\u0442\u0432\u0438\u0438. \u0422\u0430\u043a\u043e\u0439 \u0442\u0435\u0441\u0442 \u044f \u0438\u043c\u0438\u0442\u0438\u0440\u043e\u0432\u0430\u043b \u043a\u0443\u0447\u0435\u0439 \u0431\u043e\u043b\u044c\u0448\u0438\u0445 \u0438 \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0438\u0445 <code>UPDATE<\/code>. \u041f\u0430\u0440\u0430\u043b\u043b\u0435\u043b\u044c\u043d\u043e \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u0438\u044e \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u043b \u043a\u043e\u043c\u0430\u043d\u0434\u044b \u0432 \u043a\u043e\u043d\u0441\u043e\u043b\u0438:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\"> sudo btrfs subvolume snapshot \/var\/opt\/mssql\/data\/btrfs\/work\/sof1 \/var\/opt\/mssql\/data\/btrfs\/work\/sof1_x<\/code><\/pre>\n<p>  <\/p>\n<p>\u0412\u043c\u0435\u0441\u0442\u043e \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0433\u043e x \u2014 \u043d\u043e\u043c\u0435\u0440\u0430 \u0441\u043d\u0435\u043f\u0448\u043e\u0442\u043e\u0432 1..6. \u041f\u0440\u0438 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0438, \u043a\u0430\u043a \u0438 \u043e\u0436\u0438\u0434\u0430\u0435\u0442\u0441\u044f, \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043e\u0442\u043a\u0430\u0442 \u043d\u0435\u0437\u0430\u0432\u0435\u0440\u0448\u0451\u043d\u043d\u044b\u0445 \u0442\u0440\u0430\u043d\u0437\u0430\u043a\u0446\u0438\u0439, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 \u0435\u0441\u043b\u0438 \u0432 \u0442\u0435\u0441\u0442\u0435 \u043f\u0440\u043e\u0438\u0441\u0445\u043e\u0434\u0438\u0442 \u043e\u0433\u0440\u043e\u043c\u043d\u043e\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435, \u0430 \u0441\u043d\u0438\u043c\u043e\u043a \u0441\u0434\u0435\u043b\u0430\u043d \u043f\u0440\u044f\u043c\u043e \u043f\u0435\u0440\u0435\u0434 \u043a\u043e\u043c\u043c\u0438\u0442\u043e\u043c, \u0442\u043e \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u0438\u0435 \u0431\u0443\u0434\u0435\u0442 \u043e-\u043e-\u043e\u0447\u0435\u043d\u044c \u0434\u043e\u043b\u0433\u0438\u043c. \u0423 \u043c\u0435\u043d\u044f \u043d\u0430 \u043f\u043e\u0434\u043a\u043b\u044e\u0447\u0435\u043d\u043d\u044b\u0445 \u0411\u0414 \u0443\u0441\u043f\u0435\u0448\u043d\u043e \u043f\u0440\u043e\u0448\u0451\u043b <code>dbcc checkdb<\/code>, \u0431\u0430\u0437\u0430 \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0430\u0441\u044c \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u043e\u0439. \u0412 \u043a\u043e\u043d\u0446\u0435 \u043a\u043e\u043d\u0446\u043e\u0432, \u043c\u044b \u043d\u0435 \u043d\u0430 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432\u0435, \u0430 \u0434\u0430\u0436\u0435 8 \u0440\u0430\u0431\u043e\u0442\u043e\u0441\u043f\u043e\u0441\u043e\u0431\u043d\u044b\u0445 \u0441\u043d\u0435\u043f\u0448\u043e\u0442\u043e\u0432 \u0438\u0437 10 \u043c\u043e\u0433\u0443\u0442 \u043f\u043e\u043c\u043e\u0447\u044c \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u044b\u0439 \u0442\u0435\u0441\u0442.<\/p>\n<p>  <\/p>\n<p>\u041a\u0441\u0442\u0430\u0442\u0438, \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0438\u0439 \u0445\u0438\u043d\u0442. \u0414\u043b\u044f \u0430\u043d\u0430\u043b\u0438\u0437\u0430 \u0440\u0430\u0437\u043d\u0438\u0446\u044b \u0432 \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u0432\u0443\u0445 \u0442\u0430\u0431\u043b\u0438\u0446 \u0443\u0434\u043e\u0431\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c EXCEPT:<\/p>\n<p>  <\/p>\n<pre><code class=\"sql\">\/* SQL Server *\/ USE [master];  \/* \u0412 \u043e\u0434\u043d\u0443 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 *\/ SELECT * FROM [work_btrfs_sof_1].[dbo].[Users] u EXCEPT SELECT * FROM [snp_btrfs_sof_1_5].[dbo].[Users] u;  \/* \u0412 \u0434\u0440\u0443\u0433\u0443\u044e \u0441\u0442\u043e\u0440\u043e\u043d\u0443 *\/ SELECT * FROM [snp_btrfs_sof_1_5].[dbo].[Users] u EXCEPT SELECT * FROM [work_btrfs_sof_1].[dbo].[Users] u;<\/code><\/pre>\n<p>  <\/p>\n<p>\u0427\u0430\u0441\u0442\u043e \u0442\u0430\u043a\u043e\u0439 \u0432\u0430\u0440\u0438\u0430\u043d\u0442 \u0443\u0434\u043e\u0431\u043d\u0435\u0435 \u0441\u043e\u0435\u0434\u0438\u043d\u0435\u043d\u0438\u044f \u0432\u044b\u0431\u043e\u0440\u043e\u043a (join), \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u0432\u044b\u0431\u043e\u0440\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043d\u0435 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0439 \u0438\u043b\u0438 \u043a\u043b\u044e\u0447 \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u0438\u0437 \u0431\u043e\u043b\u044c\u0448\u043e\u0433\u043e \u0447\u0438\u0441\u043b\u0430 \u0441\u0442\u043e\u043b\u0431\u0446\u043e\u0432.<\/p>\n<p>  <\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f \u043f\u043e\u0434\u0442\u043e\u043c\u0430 \u043c\u043e\u0436\u043d\u043e \u0443\u0434\u0430\u043b\u044f\u0442\u044c:<\/p>\n<p>  <\/p>\n<pre><code class=\"bash\"> sudo btrfs subvolume delete \/var\/opt\/mssql\/data\/btrfs\/work\/sof1_x<\/code><\/pre>\n<p>  <\/p>\n<h2 id=\"vyvody-i-sravnenie-resheniy\">\u0412\u044b\u0432\u043e\u0434\u044b \u0438 \u0441\u0440\u0430\u0432\u043d\u0435\u043d\u0438\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0439<\/h2>\n<p>  <\/p>\n<p>\u0412\u0441\u0451, \u0447\u0442\u043e \u0441\u0434\u0435\u043b\u0430\u043d\u043e \u2014 \u044d\u0442\u043e \u043b\u0438\u0448\u044c \u0434\u0435\u043c\u043e\u043d\u0441\u0442\u0440\u0430\u0446\u0438\u044f \u0438\u0434\u0435\u0438, \u0441 \u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u043c\u043e\u0436\u043d\u043e \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0438 \u043d\u0430\u0447\u0430\u0442\u044c \u043f\u0438\u0441\u0430\u0442\u044c \u0441\u043a\u0440\u0438\u043f\u0442\u044b \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0430\u0446\u0438\u0438 \u0440\u0430\u0437\u0432\u0451\u0440\u0442\u044b\u0432\u0430\u043d\u0438\u044f \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0445 \u0441\u0440\u0435\u0434 (\u0432 \u0432\u0430\u0448\u0435\u043c \u043b\u044e\u0431\u0438\u043c\u043e\u043c CI\/CD \u0442\u0443\u043b\u0438\u043d\u0433\u0435, \u043d\u0430\u043f\u0440\u0438\u043c\u0435\u0440). \u041a\u0430\u043a \u0433\u043e\u0432\u043e\u0440\u0438\u0442\u0441\u044f \u0432 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u0445 \u0443\u0447\u0435\u0431\u043d\u0438\u043a\u0430\u0445 \u0438 \u043b\u0435\u043a\u0446\u0438\u044f\u0445 &#171;\u044d\u0442\u043e \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0435\u0442\u0441\u044f \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u044e \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043d\u0435\u0441\u043b\u043e\u0436\u043d\u043e\u0433\u043e \u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e\u0433\u043e \u0443\u043f\u0440\u0430\u0436\u043d\u0435\u043d\u0438\u044f&#187;. \u041d\u0443 \u0438 \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0439\u0442\u0435, \u0447\u0442\u043e CoW \u0432\u0441\u0451-\u0442\u0430\u043a\u0438 \u0437\u0430\u043c\u0435\u0442\u043d\u043e \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u044c.<\/p>\n<p>  <\/p>\n<p>\u0427\u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u043f\u043e \u0440\u0430\u0437\u043d\u0438\u0446\u0435 \u0424\u0421:<\/p>\n<p>  <\/p>\n<div class=\"scrollable-table\">\n<table>\n<thead>\n<tr>\n<th>XFS<\/th>\n<th>BTRFS<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>\u041f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043e\u0444\u0438\u0446\u0438\u0430\u043b\u044c\u043d\u043e<\/td>\n<td>\u0412\u0440\u043e\u0434\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442<\/td>\n<\/tr>\n<tr>\n<td>\u041f\u043e\u0444\u0430\u0439\u043b\u043e\u0432\u043e\u0435 \u043a\u043e\u043f\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435<\/td>\n<td>\u041c\u043e\u043c\u0435\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0441\u043d\u0438\u043c\u043a\u0438 \u043f\u043e\u0434\u0442\u043e\u043c\u0430<\/td>\n<\/tr>\n<tr>\n<td>\u0411\u0430\u0437\u0430 \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043e\u043b\u0436\u043d\u0430 \u0431\u044b\u0442\u044c OFFLINE<\/td>\n<td>\u041c\u043e\u0436\u043d\u043e \u0440\u0438\u0441\u043a\u043d\u0443\u0442\u044c \u0441 \u0441\u043e\u0437\u0434\u0430\u043d\u0438\u0435\u043c \u0441\u043d\u0438\u043c\u043a\u043e\u0432 &#171;\u043d\u0430 \u043b\u0435\u0442\u0443&#187;<\/td>\n<\/tr>\n<tr>\n<td>\u0421\u0447\u0438\u0442\u0430\u0435\u0442\u0441\u044f \u0431\u043e\u043b\u0435\u0435 \u0431\u044b\u0441\u0442\u0440\u043e\u0439<\/td>\n<td>\u041f\u0440\u043e\u0438\u0433\u0440\u044b\u0432\u0430\u0435\u0442 \u0432 \u0442\u0435\u0441\u0442\u0430\u0445 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438<\/td>\n<\/tr>\n<tr>\n<td>\u0421\u043b\u043e\u0436\u043d\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u0439 \u043e\u0431\u044a\u0451\u043c<\/td>\n<td>\u0423\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435<\/td>\n<\/tr>\n<tr>\n<td>\u041f\u0440\u043e\u0449\u0435 \u0432 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0438<\/td>\n<td>\u0411\u043e\u043b\u044c\u0448\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439<\/td>\n<\/tr>\n<tr>\n<td>\u041c\u043e\u0436\u043d\u043e \u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c \u0431\u0435\u0437 root<\/td>\n<td>\u042f \u043d\u0435 \u0437\u043d\u0430\u044e, \u043a\u0430\u043a \u043e\u0431\u043e\u0439\u0442\u0438\u0441\u044c \u0431\u0435\u0437 root (\u043c\u043e\u0436\u0435\u0442 \u0438 \u043c\u043e\u0436\u043d\u043e)<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<p>  <\/p>\n<p>\u0422\u0435\u0441\u0442\u044b \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u043e\u0441\u0442\u0438 \u044f \u043d\u0435 \u0434\u0435\u043b\u0430\u043b, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e <del>\u043c\u043d\u0435 \u043b\u0435\u043d\u044c<\/del> \u043e\u043d\u0438 \u0441\u0438\u043b\u044c\u043d\u043e \u0437\u0430\u0432\u0438\u0441\u044f\u0442 \u043e\u0442 \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u0441\u0446\u0435\u043d\u0430\u0440\u0438\u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u044f. \u042f \u0431\u044b \u043e\u0436\u0438\u0434\u0430\u043b \u043f\u0430\u0434\u0435\u043d\u0438\u044f \u0432 2-2,5 \u0440\u0430\u0437\u0430 \u043d\u0430 \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u044f\u0445 \u0437\u0430\u043f\u0438\u0441\u0438 \u0432 \u0444\u0430\u0439\u043b\u044b, \u043d\u043e \u043d\u0430\u0434\u043e \u043f\u043e\u043c\u043d\u0438\u0442\u044c, \u0447\u0442\u043e \u0434\u0430\u0436\u0435 \u0432 \u043e\u0447\u0435\u043d\u044c \u0430\u043a\u0442\u0438\u0432\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u043d\u0430 \u0437\u0430\u043f\u0438\u0441\u044c \u0440\u0435\u043b\u044f\u0446\u0438\u043e\u043d\u043d\u044b\u0445 OLTP \u0441\u0438\u0441\u0442\u0435\u043c\u0430\u0445 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043e\u043f\u0435\u0440\u0430\u0446\u0438\u0439 \u0437\u0430\u043f\u0438\u0441\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 5-10% \u043e\u0442 \u043e\u0431\u0449\u0435\u0433\u043e \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u0430.<\/p>\n<p>  <\/p>\n<p>\u041f\u043e\u043c\u0438\u043c\u043e \u043f\u0440\u044f\u043c\u043e\u0439 \u0432\u044b\u0433\u043e\u0434\u044b \u0432 \u0434\u0438\u0441\u043a\u043e\u0432\u043e\u043c \u043f\u0440\u043e\u0441\u0442\u0440\u0430\u043d\u0441\u0442\u0432\u0435, \u043f\u0440\u0435\u0434\u043b\u043e\u0436\u0435\u043d\u043d\u0430\u044f \u0441\u0438\u0441\u0442\u0435\u043c\u0430 \u0440\u0435\u0448\u0430\u0435\u0442 \u0435\u0449\u0435 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0432\u0430\u0436\u043d\u0435\u0439\u0448\u0438\u0445 \u0437\u0430\u0434\u0430\u0447:<\/p>\n<p>  <\/p>\n<ol>\n<li>\u0421\u0438\u043b\u044c\u043d\u043e \u0441\u043e\u043a\u0440\u0430\u0449\u0430\u0435\u0442 \u0432\u0440\u0435\u043c\u044f \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0438 \u0438 \u043e\u0431\u044a\u0451\u043c \u0442\u0435\u0441\u0442\u043e\u0432\u043e\u0433\u043e \u0441\u0442\u0435\u043d\u0434\u0430. \u041d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e, \u0447\u0442\u043e \u043f\u043e\u0434 \u043a\u0430\u0436\u0434\u044b\u0439 \u0442\u0435\u0441\u0442 \u043c\u043e\u0436\u043d\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0441\u0442\u0435\u043d\u0434<\/li>\n<li>\u041f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u043d\u0435\u043f\u043b\u043e\u0445\u043e \u0430\u0432\u0442\u043e\u043c\u0430\u0442\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u044b \u0438 CI\/CD<\/li>\n<li>\u041f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0434\u0435\u043b\u0430\u0442\u044c \u043c\u043d\u043e\u0433\u043e \u0441\u0442\u0435\u043d\u0434\u043e\u0432 \u0438 \u0442\u043e\u0447\u0435\u043a \u0432\u043e\u0441\u0441\u0442\u0430\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u044f, \u0447\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u043f\u043e\u043c\u043e\u0447\u044c \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c \u0441\u043b\u043e\u0436\u043d\u044b\u0439 \u043a\u0435\u0439\u0441<\/li>\n<\/ol>\n<p>  <\/p>\n<h2 id=\"mysli-vsluh-preduprezhdeniya-i-predosterezheniya\">\u041c\u044b\u0441\u043b\u0438 \u0432\u0441\u043b\u0443\u0445, \u043f\u0440\u0435\u0434\u0443\u043f\u0440\u0435\u0436\u0434\u0435\u043d\u0438\u044f \u0438 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0435\u0440\u0435\u0436\u0435\u043d\u0438\u044f<\/h2>\n<p>  <\/p>\n<p>\u041d\u0435\u0431\u043e\u043b\u044c\u0448\u0438\u0435 \u0437\u0430\u043c\u0435\u0442\u043a\u0438 \u043d\u0430 \u043f\u043e\u043b\u044f\u0445:<\/p>\n<p>  <\/p>\n<ul>\n<li>\u041d\u0438\u043a\u0442\u043e \u043d\u0435 \u043c\u0435\u0448\u0430\u0435\u0442 \u043f\u0440\u0438\u043c\u0435\u043d\u0438\u0442\u044c \u0442\u0443 \u0436\u0435 \u0442\u0435\u0445\u043d\u0438\u043a\u0443 \u043a \u0434\u0440\u0443\u0433\u0438\u043c \u0432\u0438\u0434\u0430\u043c \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0445 \u0441\u0440\u0435\u0434 \u0438\u043b\u0438 \u043a \u0434\u0440\u0443\u0433\u0438\u043c \u0437\u0430\u0434\u0430\u0447\u0430\u043c. \u0412 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438, \u043d\u0430 \u043f\u0440\u043e\u0441\u0442\u043e\u0440\u0430\u0445 \u0418\u043d\u0442\u0435\u0440\u043d\u0435\u0442\u0430 \u044f \u0432\u0441\u0442\u0440\u0435\u0447\u0430\u043b \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u044b \u0441 <a href=\"https:\/\/github.com\/plcarmel\/fs-cow\" rel=\"nofollow noopener noreferrer\">PostgreSQL<\/a>. \u0427\u0435\u0441\u0442\u043d\u043e \u0433\u043e\u0432\u043e\u0440\u044f, \u0434\u0430\u0436\u0435 \u043d\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u044e, \u043f\u043e\u0447\u0435\u043c\u0443 \u0432 pg \u043a\u043b\u043e\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u0411\u0414 \u0432 \u0441\u0430\u043c \u0434\u0432\u0438\u0436\u043e\u043a \u043d\u0435 \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043e.<\/li>\n<li>\u042d\u0442\u0430 \u0442\u0435\u0445\u043d\u0438\u043a\u0430 \u043c\u043e\u0436\u0435\u0442 \u0431\u044b\u0442\u044c \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043b\u0435\u0437\u043d\u0430 \u043a\u043e\u043b\u043b\u0435\u043a\u0442\u0438\u0432\u0430\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u043a\u043e\u0440\u043f\u043e\u0440\u0430\u0442\u0438\u0432\u043d\u044b\u0445 \u0441\u0438\u0441\u0442\u0435\u043c \u043d\u0430 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u0435 1\u0421: \u041f\u0440\u0435\u0434\u043f\u0440\u0438\u044f\u0442\u0438\u0435. \u0421\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u044d\u0442\u043e\u0442 \u043f\u0440\u0438\u043c\u0435\u0440 \u0441\u0434\u0435\u043b\u0430\u043d \u0441\u043f\u0435\u0446\u0438\u0430\u043b\u044c\u043d\u043e \u0434\u043b\u044f \u043d\u0430\u0448\u0435\u0439 \u043a\u043e\u043c\u0430\u043d\u0434\u044b 1\u0421\u043d\u0438\u043a\u043e\u0432 \u0441 \u0431\u043e\u043b\u044c\u0448\u0438\u043c \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e\u043c \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432 \u0438 \u043a\u043e\u043d\u0442\u0443\u0440\u043e\u0432.<\/li>\n<li>&#171;\u0412\u0441\u0435 \u0442\u0440\u044e\u043a\u0438 \u0432\u044b\u043f\u043e\u043b\u043d\u0435\u043d\u044b <del>\u043f\u0440\u043e\u0444\u0435\u0441\u0441\u0438\u043e\u043d\u0430\u043b\u0430\u043c\u0438<\/del> \u0434\u0438\u043b\u0435\u0442\u0430\u043d\u0442\u043e\u043c <del>\u043d\u0435<\/del> \u043f\u044b\u0442\u0430\u0439\u0442\u0435\u0441\u044c \u043f\u043e\u0432\u0442\u043e\u0440\u0438\u0442\u044c \u044d\u0442\u043e \u0441\u0430\u043c\u043e\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u043d\u043e&#187;. \u041d\u043e \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0439\u0442\u0435 \u043e \u0442\u0435\u0445\u043d\u0438\u043a\u0435 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u0438 \u2014 \u043d\u0435 \u0442\u0430\u0449\u0438\u0442\u0435 \u044d\u0442\u0443 \u043f\u043e\u0434\u0435\u043b\u0443\u0445\u0443 \u0432 \u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u044b\u0439 \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u0438\u0432. <em>(\u041f\u0440\u043e \u0434\u0438\u043b\u0435\u0442\u0430\u043d\u0442\u0430 \u044f \u0441\u043e\u0432\u0440\u0430\u043b \ud83d\ude42 )<\/em><\/li>\n<li>\u0412\u0441\u0435 \u0441\u043e\u0431\u044b\u0442\u0438\u044f \u0438 \u043e\u0431\u0441\u0442\u043e\u044f\u0442\u0435\u043b\u044c\u0441\u0442\u0432\u0430 \u043f\u043e\u0447\u0442\u0438 \u0432\u044b\u043c\u044b\u0448\u043b\u0435\u043d\u044b \u0438 \u043b\u044e\u0431\u044b\u0435 \u0441\u043e\u0432\u043f\u0430\u0434\u0435\u043d\u0438\u044f \u043f\u043e\u0447\u0442\u0438 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u044b.<\/li>\n<li>\u0421\u043f\u0430\u0441\u0438\u0431\u043e \u0442\u0435\u043c, \u043a\u0442\u043e \u043f\u043e\u043c\u043e\u0433\u0430\u043b \u0432 \u0432\u044b\u0447\u0438\u0442\u044b\u0432\u0430\u043d\u0438\u0438 \u0438 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u0438 \u0441\u0442\u0430\u0442\u044c\u0438.<\/li>\n<\/ul>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/691030\/\"> https:\/\/habr.com\/ru\/post\/691030\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-1\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w780q1\/webt\/7m\/mr\/sv\/7mmrsvigkrcas7ajrcjgbbgrjzk.jpeg\" alt=\"CoW\" data-src=\"https:\/\/habrastorage.org\/webt\/7m\/mr\/sv\/7mmrsvigkrcas7ajrcjgbbgrjzk.jpeg\" data-blurred=\"true\"\/><\/p>\n<p>  <\/p>\n<p>\u0412 \u043c\u0438\u0440\u0435 \u043a\u0440\u043e\u0432\u0430\u0432\u043e\u0433\u043e \u044d\u043d\u0442\u0435\u0440\u043f\u0440\u0430\u0439\u0437\u0443 \u0435\u0441\u0442\u044c \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432-\u043c\u0430\u043c\u043e\u043d\u0442\u043e\u0432. \u041e\u043d\u0438 \u0431\u043e\u043b\u044c\u0448\u0438\u0435, \u0443 \u043d\u0438\u0445 \u0431\u0430\u0437\u044b \u0434\u0430\u043d\u043d\u044b\u0445 \u043d\u0430 SQL Server, \u0432 \u044d\u0442\u0438\u0445 \u0431\u0430\u0437\u0430\u0445 \u0442\u044b\u0441\u044f\u0447\u0438 \u0438 \u0434\u0435\u0441\u0442\u044f\u043a\u0438 \u0442\u044b\u0441\u044f\u0447 \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432, \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u044b \u0441\u0442\u0440\u043e\u043a \u043a\u043e\u0434\u0430 T-SQL, \u043e\u0433\u0440\u043e\u043c\u043d\u0430\u044f \u0432\u0430\u0440\u0438\u0430\u0442\u0438\u0432\u043d\u043e\u0441\u0442\u044c \u0434\u0430\u043d\u043d\u044b\u0445, \u0432\u0441\u0451 \u0445\u0440\u0443\u043f\u043a\u043e\u0435, \u043d\u0435\u0438\u0434\u0435\u043c\u043f\u043e\u0442\u0435\u043d\u0442\u043d\u043e\u0435, \u043d\u0435\u0434\u0435\u0442\u0435\u0440\u043c\u0438\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435 \u0438 \u0444\u0438\u0433\u043e\u0432\u043e \u0434\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0435. \u041a\u043e\u0440\u043e\u0447\u0435, \u043a\u0430\u043a \u043f\u0438\u0441\u0430\u043b Roy Osherove \u0432 \u0441\u0432\u043e\u0435\u0439 The art of unit-testing:<\/p>\n<p>  <\/p>\n<blockquote><p>Finally, as a friend once said, a good bottle of vodka never hurts when dealing with legacy code.<\/p><\/blockquote>\n<p>\u0412 \u0432\u043e\u043b\u044c\u043d\u043e\u043c \u043f\u0435\u0440\u0435\u0432\u043e\u0434\u0435 &#171;\u0414\u0430 \u0442\u0430\u043c \u0431\u0435\u0437 \u043f\u043e\u043b\u043b\u0438\u0442\u0440\u044b \u043d\u0435 \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u0448\u044c\u0441\u044f!&#187;<\/p>\n<p>  <\/p>\n<p>\u0418 \u0432\u043e\u0442 \u0443 \u044d\u0442\u0438\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0435\u0441\u0442\u044c \u0431\u0435\u0434\u0430 \u2014 \u0431\u043e\u043b\u044c\u0448\u0438\u0435 \u043a\u043e\u043d\u0442\u0443\u0440\u044b \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0438 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438, \u0447\u0430\u0441\u0442\u043e \u0442\u0430\u043a \u0438\u043b\u0438 \u0438\u043d\u0430\u0447\u0435 \u043c\u043e\u0434\u0438\u0444\u0438\u0446\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0435 \u0438 \u0443\u043c\u0435\u043d\u044c\u0448\u0435\u043d\u043d\u044b\u0435 \u043a\u043e\u043f\u0438\u0438 \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0433\u043e \u043f\u0440\u043e\u0434\u0443\u043a\u0442\u043e\u0432\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0443\u0440\u0430. \u0414\u0430-\u0434\u0430-\u0434\u0430, \u0442\u0443\u0442 \u0441\u0440\u0430\u0437\u0443 \u043f\u043e\u043d\u0430\u043b\u0435\u0442\u044f\u0442 \u0443\u043c\u043d\u044b\u0435 \u0434\u0430 \u0432 \u0431\u0435\u043b\u043e\u0439 \u043e\u0434\u0435\u0436\u0434\u0435 \u0438 \u043d\u0430\u0447\u043d\u0443\u0442 \u043e\u0431\u044a\u044f\u0441\u043d\u044f\u0442\u044c, \u0447\u0442\u043e \u043d\u0430\u0434\u043e \u043f\u0438\u0441\u0430\u0442\u044c \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0435 \u043d\u0430\u0431\u043e\u0440\u044b \u0434\u0430\u043d\u043d\u044b\u0445 (\u0430 \u043a\u0442\u043e \u0441\u043f\u043e\u0440\u0438\u0442?), \u0447\u0442\u043e \u0442\u0435\u0441\u0442\u043e\u0432\u044b\u0439 \u043a\u043e\u043d\u0442\u0443\u0440 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043d\u0435\u0431\u043e\u043b\u044c\u0448\u0438\u043c (\u0430 \u043a\u0442\u043e \u0441\u043f\u043e\u0440\u0438\u0442?), \u0447\u0442\u043e \u043a\u043e\u0434 \u0434\u043e\u043b\u0436\u0435\u043d \u0431\u044b\u0442\u044c \u043f\u0435\u0440\u0435\u043d\u043e\u0441\u0438\u043c\u044b\u043c \u043c\u0435\u0436\u0434\u0443 \u0421\u0423\u0411\u0414 (\u0441\u043f\u0430\u0441\u0438\u0431\u043e, \u041a\u044d\u043f!), \u0447\u0442\u043e \u0432\u0441\u0451 \u0431\u044b\u043b\u043e \u0431\u044b \u043b\u0443\u0447\u0448\u0435, \u0435\u0441\u043b\u0438 \u0431\u044b \u043f\u0440\u043e\u0435\u043a\u0442 \u043f\u0435\u0440\u0435\u043f\u0438\u0441\u0430\u043b\u0438 N \u043b\u0435\u0442 \u043d\u0430\u0437\u0430\u0434 (\u0445\u0430-\u0445\u0430) \u0438 \u043f\u0440\u043e\u0447\u0438\u0435 &#171;\u0441\u0442\u0430\u043d\u044c\u0442\u0435 \u0451\u0436\u0438\u043a\u0430\u043c\u0438&#187; \u0438 &#171;\u043f\u0443\u0441\u0442\u044c \u0435\u0434\u044f\u0442 \u043f\u0438\u0440\u043e\u0436\u043d\u044b\u0435&#187;. \u041d\u0435\u0442, \u0434\u043e\u0440\u043e\u0433\u0438\u0435 \u043c\u043e\u0438. \u041f\u0440\u043e\u0441\u0442\u043e \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u044c\u0442\u0435, \u0447\u0442\u043e \u0443 \u0432\u0430\u0441 \u0435\u0441\u0442\u044c \u0411\u0414 SQL Server \u0441 25\u041a \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 (\u0442\u0430\u0431\u043b\u0438\u0446 \u0438 \u0425\u041f) \u0438 \u043c\u0438\u043b\u043b\u0438\u043e\u043d\u0430\u043c\u0438 \u0441\u0442\u0440\u043e\u043a \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u0438 \u0447\u0430\u0441\u0442\u044c \u043e\u0431\u044a\u0435\u043a\u0442\u043e\u0432 \u0441\u043e\u0437\u0434\u0430\u043d\u0430 \u0441 <code>SET ANSI NULLS ON<\/code>, \u0430 \u0447\u0430\u0441\u0442\u044c \u0441 <code>SET ANSI NULLS OFF<\/code>. \u0418 \u0442\u043e\u0447\u043d\u043e \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e, \u0447\u0442\u043e \u0432 \u0447\u0430\u0441\u0442\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432 \u044d\u0442\u0430 \u0440\u0430\u0437\u043d\u0438\u0446\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f. \u0418 \u0411\u0414 \u043d\u0430 \u0434\u0435\u0441\u0442\u044f\u043a\u0438 \u0422\u0438\u0411. \u0418 \u043e\u0434\u043d\u043e\u0434\u043d\u0435\u0432\u043d\u044b\u0439 \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u0441\u0442\u043e\u0438\u0442 \u0431\u043e\u043b\u044c\u0448\u0435, \u0447\u0435\u043c \u043a\u0432\u0430\u0440\u0442\u0438\u0440\u044b \u0432\u0441\u0435\u0445 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0447\u0438\u043a\u043e\u0432, \u043a\u043e\u0442\u043e\u0440\u044b\u0435 \u0437\u0430 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0435 20 \u043b\u0435\u0442 \u0442\u0440\u043e\u0433\u0430\u043b\u0438 \u044d\u0442\u043e\u0442 \u043a\u043e\u0434 (\u0438\u0437 \u043a\u043e\u0442\u043e\u0440\u044b\u0445, \u043a\u0441\u0442\u0430\u0442\u0438, \u0441\u0435\u0439\u0447\u0430\u0441 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0442\u043e\u043b\u044c\u043a\u043e 7 \u043f\u043e\u0441\u043b\u0435\u0434\u043d\u0438\u0445 \u0441\u0430\u043c\u0443\u0440\u0430\u0435\u0432). \u041e\u0434\u043d\u043e \u044d\u0442\u043e \u043c\u043e\u0436\u0435\u0442 \u043d\u0435 \u0434\u0430\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0439\u0442\u0438 \u0441 SQL Server 2008 R2 \u043d\u0430 \u0447\u0442\u043e-\u0442\u043e \u0431\u043e\u043b\u0435\u0435 \u0441\u0432\u0435\u0436\u0435\u0435 \u043f\u0430\u0440\u0443 \u043b\u0435\u0442.<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-339880","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/339880","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=339880"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/339880\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=339880"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=339880"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=339880"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}