{"id":3859,"date":"2012-07-12T06:49:46","date_gmt":"2012-07-11T20:49:46","guid":{"rendered":"http:\/\/nsrd.info\/blog\/?p=3859"},"modified":"2012-07-12T06:49:46","modified_gmt":"2012-07-11T20:49:46","slug":"networker-8-advanced-file-type-devices","status":"publish","type":"post","link":"https:\/\/nsrd.info\/blog\/2012\/07\/12\/networker-8-advanced-file-type-devices\/","title":{"rendered":"NetWorker 8 Advanced File Type Devices"},"content":{"rendered":"<p>As mentioned in my main NetWorker 8 introduction article, one of the biggest architectural enhancements in NetWorker v8 is a complete overhaul of the backup to disk architecture. This isn&#8217;t an update to AFTDs, it&#8217;s a complete restart \u2013 the architecture that was is no longer, and it&#8217;s been replaced by something newer, fresher, and more scalable.<\/p>\n<p>In order to understand what&#8217;s involved in the changes, we first need to step back and consider how the AFTD architecture works in NetWorker v7.x. For the purposes of my examples, I&#8217;m going to consider a theoretical 10TB of disk backup capacity available to a NetWorker server. Now, under v7.x, you&#8217;d typically end up with filesystems and AFTDs that look like the following:<\/p>\n<p><a href=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v7.x-AFTD.jpg\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-3860\" title=\"AFTD changes - v7.x AFTD\" src=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v7.x-AFTD.jpg\" alt=\"AFTD changes - v7.x AFTD\" width=\"494\" height=\"604\" srcset=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v7.x-AFTD.jpg 494w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v7.x-AFTD-245x300.jpg 245w\" sizes=\"auto, (max-width: 494px) 100vw, 494px\" \/><\/a><\/p>\n<p>(In the above diagram, and those to follow, a red line\/arrow indicates a write session coming into the AFTD, and a green line\/arrow indicates a read session coming out of the AFTD.)<\/p>\n<p>That is, you&#8217;d slice and dice that theoretical 10TB of disk capacity into a bunch of smaller sized filesystems, with typically one AFTD per filesystem. In 7.x, there are two nsrmmd processes per AFTD \u2013 one to handle write operations (the main\/real path to the AFTD), and one to handle read operations from the AFTD device \u2013 the shadow or _AF_readonly path on the volume.<\/p>\n<p>So AFTDs under this scenario delivered simultaneous backup and recovery operations by a bit of sleight-of-hand; in some ways, NetWorker was\u00a0<em>tricked<\/em> into thinking it was dealing with two different volumes. In fact, that&#8217;s what lead to there being two instances of a saveset in the media database for any saveset created on AFTD \u2013 one for the read\/write volume, and one of the read-only volume, with a clone ID of 1 less than the instance on the read\/write volume. This didn&#8217;t double the storage; the &#8220;trick&#8221; was largely maintained in the media database, with just a few meta files maintained in the _AF_readonly path of the device.<\/p>\n<p>Despite the improved backup options offered by v7.x AFTDs, there were several challenges introduced that somewhat limited the applicability of AFTDs in larger backup scenarios. Much as I&#8217;ve never <em>particularly<\/em> liked virtual tape libraries (seeing them as a solution to a problem that shouldn&#8217;t exist), I found myself typically recommending a VTL for disk backup in NetWorker ahead of AFTDs. The challenges in particular, as I saw them, were:<\/p>\n<ul>\n<li>Limits on concurrency between staging, cloning and recovery from AFTDs meant that businesses often struggled to clone and reclaim space non-disruptively. Despite the inherent risks, this lead to many decisions not to clone data first, meaning only one copy was ever kept;<\/li>\n<li>Because of those limits, disk backup units would need to be sliced into smaller allotments &#8211; such as the 5 x 2TB devices cited in the above diagram, so that space reclamation would be for smaller, more discrete chunks of data, but spread across more devices simultaneously;<\/li>\n<li>A saveset could never exceed the amount of free space on an AFTD \u2013 NetWorker doesn&#8217;t support continuing a saveset from one full AFTD to another;<\/li>\n<li>Larger savesets would be manually sliced up by the administrator to fit on an AFTD, introducing human error, or would be sent direct to tape, potentially introducing shoe-shining back into the backup configuration.<\/li>\n<\/ul>\n<p>As a result of this, a lot of AFTD layouts saw them more being used as glorified staging units, rather than providing a significant amount of near-line recoverability options.<\/p>\n<p>Another, more subtle problem from this architecture was that nsrmmd itself is not a process geared towards a high amount of concurrency; while based on its name (media multiplexor daemon) we know that it&#8217;s always been designed to deal with a certain number of concurrent streams for tape based multiplexing, there are limits to how many savesets an nsrmmd process can handle simultaneously before it starts to dip in efficiency. This was never so much an issue with physical tape \u2013 as most administrators would agree, using multiplexing above 4 for any physical tape will continue to work, but may result in backups which are much slower to recover from if a full filesystem\/saveset recovery is required, rather than a small random chunk of data.<\/p>\n<p>NetWorker administrators who have been using AFTD for a while will equally agree that pointing a large number of savesets at an AFTD doesn&#8217;t guarantee high performance \u2013 while disk doesn&#8217;t shoe-shine, the drop-off in nsrmmd efficiency per saveset would start to be quite noticeable at a saveset concurrency of around 8 if client and network performance were not the bottleneck in the environment.<\/p>\n<p>This further encouraged slicing and dicing disk backup capacity \u2013 why allocate 10TB of capacity to a single AFTD if you&#8217;d get better concurrency out of 5 x 2TB AFTDs? To minimise the risk of any individual AFTD filling while others still had capacity, you&#8217;d configure the AFTDs to each have target sessions of 1 &#8211; effectively round-robbining the \u00a0starting of savesets across all the units.<\/p>\n<p>I think that pretty much provides a good enough overview about AFTDs under v7.x that can talk about AFTDs in NetWorker v8.<\/p>\n<p>Keeping that 10TB of disk backup capacity in play, under NetWorker v8, you&#8217;d optimally end up with the following configuration:<\/p>\n<p><a href=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD.jpg\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-3861\" title=\"AFTD changes - v8.x AFTD\" src=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD.jpg\" alt=\"AFTD changes - v8.x AFTD\" width=\"474\" height=\"518\" srcset=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD.jpg 474w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD-274x300.jpg 274w\" sizes=\"auto, (max-width: 474px) 100vw, 474px\" \/><\/a><\/p>\n<p>You&#8217;re seeing that right \u2013 multiple nsrmmd processes for a single AFTD \u2013 and I don&#8217;t mean a read\/write nsrmmd and a shadow-volume read-only nsrmmd as per v7.x. In fact, the entire concept and implementation of the shadow volume goes away under NetWorker v8. It&#8217;s not needed any longer.\u00a0<strong>Huzzah!<\/strong><\/p>\n<p>Assuming dynamic nsrmmd spawning (yes), and up to certain limits, NetWorker will now spawn one nsrmmd process for an AFTD each time it hits the\u00a0<em>target sessions<\/em> setting for the AFTD volume. That raises one immediate change \u2013 for a v8.x AFTD configuration, bump up the target sessions for the devices. Otherwise you&#8217;ll end up spawning a lot more nsrmmd processes than are appropriate. Based on feedback from EMC, it would seem that the optimum target setting for a consolidate AFTD is 4. Assuming linear growth, this would mean that you&#8217;d have the following spawning rate:<\/p>\n<ul>\n<li>1 saveset, 1 x nsrmmd<\/li>\n<li>2 savesets, 1 x nsrmmd<\/li>\n<li>3 savesets, 1 x nsrmmd<\/li>\n<li>4 savesets, 1 x nsrmmd<\/li>\n<li>5 savesets, 2 x nsrmmd<\/li>\n<li>6 savesets, 2 x nsrmmd<\/li>\n<li>7 savesets, 2 x nsrmmd<\/li>\n<li>8 savesets, 2 x nsrmmd<\/li>\n<li>9 savesets, 3 x nsrmmd<\/li>\n<\/ul>\n<p>Your actual rate may vary of course, depending on cloning, staging and recovery operations also being performed at the same time. Indeed, for the time being at least, NetWorker dedicates a single nsrmmd process to any\u00a0<em>nsrclone<\/em> or\u00a0<em>nsrstage<\/em> operation that is run (either manually or as a scheduled task), and yes, you can actually simultaneously recover, stage and clone all at the same time. NetWorker handles staging in that equation by blocking capacity reclamation while a process is reading from the AFTD \u2013 this prevents a staging operation removing a saveset that is needed for recovery or cloning. In this situation, a staging operation will report as per:<\/p>\n<pre>[root@tara usr]# <strong>nsrstage -b Default -v -m -S 4244365627<\/strong>\nObtaining media database information on server tara.pmdg.lab\n80470:nsrstage: Following volumes are needed for cloning\n80471:nsrstage:         AFTD-B-1 (Regular)\n5874:nsrstage: Automatically copying save sets(s) to other volume(s)\n79633:nsrstage: \nStarting migration operation for Regular save sets...\n6217:nsrstage: ...from storage node: tara.pmdg.lab\n81542:nsrstage: Successfully cloned all requested Regular save sets (with new cloneid)\n        4244365627\/1341909730\n79629:nsrstage: Clones were written to the following volume(s) for Regular save sets:\n        800941L4\n6359:nsrstage: Deleting the successfully cloned save set 4244365627\nRecovering space from volume 15867081 failed with the error 'volume \nmounted on ADV_FILE disk AFTD1 is reading'.\nRefer to the NetWorker log for details.\n89216:nsrd: volume mounted on ADV_FILE disk AFTD1 is reading<\/pre>\n<p>When a space reclamation is subsequently run (either as part of overnight reclamation, or an explicit execution of nsrim -X), the something along the following lines will get logged:<\/p>\n<pre>nsrd NSR info Index Notice: nsrim has finished crosschecking the media db \nnsrd NSR info Media Info: No space was recovered from device AFTD2 since there was no saveset eligible for deletion. \nnsrd NSR info Media Info: No space was recovered from device AFTD4 since there was no saveset eligible for deletion. \n<em>nsrd NSR info Media Info: Deleted 87 MB from save set 4244365627 on volume AFTD-B-1 <\/em>\n<em>nsrd NSR info Media Info: Recovered 87 MB by deleting 1 savesets from device AFTD1. <\/em>\n<em>nsrsnmd NSR warning volume (AFTD-B-1) size is now set to 2868 MB<\/em><\/pre>\n<p>Thus, you shouldn&#8217;t need to worry about concurrency any longer.<\/p>\n<p>Another change introduced to the AFTD architecture is the device name is now divorced from the\u00a0<em>path<\/em>. This is stored in a different field. For example:<\/p>\n<p><a href=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-paths.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-3865\" title=\"AFTD path\/device name separation\" src=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-paths.png\" alt=\"AFTD path\/device name separation\" width=\"1016\" height=\"633\" srcset=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-paths.png 1016w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-paths-300x186.png 300w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-paths-481x300.png 481w\" sizes=\"auto, (max-width: 1016px) 100vw, 1016px\" \/><\/a><\/p>\n<p>In the above example, the AFTD device has a device name of AFTD1, and the path to it is \/d\/backup1 \u2013 or to be more accurate, the\u00a0<em>first<\/em> path to it is \/d\/backup1. I&#8217;ll get to the real import of that in a moment.<\/p>\n<p>There is a simpler management benefit: previously if you setup an AFTD and needed to later change the path that it was mounted from, you had to do the following:<\/p>\n<ol>\n<li>Unmount the disk backup unit within NetWorker<\/li>\n<li>Delete the AFTD definition within NetWorker<\/li>\n<li>Create a new AFTD definition pointing to the new location<\/li>\n<li>At the OS, remount the AFTD filesystem at the new location<\/li>\n<li>Mount the AFTD volume from its new location in NetWorker<\/li>\n<\/ol>\n<p>This was a tedious process, and the notion of &#8220;deleting&#8221; an AFTD, even though it had no bearing on the actual data stored on it, did not appeal to a lot of administrators.<\/p>\n<p>However, the first path specified to an AFTD in the &#8220;Device Access Information&#8221; field refers to the mount point on the owner storage node, so under v8, all you&#8217;ve got to do in order to relocate the AFTD is:<\/p>\n<ol>\n<li>Unmount the disk backup unit within NetWorker.<\/li>\n<li>Remount the AFTD filesystem in its new location.<\/li>\n<li>Adjust the first entry in the &#8220;Device Access Information&#8221; field.<\/li>\n<li>Remount the AFTD volume in its new location.<\/li>\n<\/ol>\n<p>This may not seem like a big change, but it&#8217;s both useful and more logical. Obviously another benefit of this is that you no longer have to remember device paths when performing manual nsrmm operations against AFTDs \u2013 you just specify the volume name. So your nsrmm commands would go from:<\/p>\n<pre># <strong>nsrmm -u -f \/d\/backup1<\/strong><\/pre>\n<p>to, in the above example:<\/p>\n<pre># <strong>nsrmm -u -f AFTD1<\/strong><\/pre>\n<p>The\u00a0<em>real<\/em> benefit of this though is what I&#8217;ve been alluding to by talking about the\u00a0<em>first<\/em> mount point specified. You can specify alternate mount points for the device. However, these aren&#8217;t additional volumes on the server \u2013 they&#8217;re mount points as seen by\u00a0<em>clients<\/em>. This allows a bypass of using nsrmmd to perform a write to a disk backup unit from the client, and instead sees the client write via whatever operating system mount mechanism it&#8217;s used (CIFS or NFS).<\/p>\n<p>In this configuration, your disk backup environment can start to look like the following:<\/p>\n<p><a href=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD-with-NFS.jpg\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-3867\" title=\"AFTD changes - v8.x AFTD with NFS\" src=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD-with-NFS.jpg\" alt=\"AFTD changes - v8.x AFTD with NFS\" width=\"737\" height=\"641\" srcset=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD-with-NFS.jpg 737w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD-with-NFS-300x260.jpg 300w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-changes-v8.x-AFTD-with-NFS-344x300.jpg 344w\" sizes=\"auto, (max-width: 737px) 100vw, 737px\" \/><\/a><\/p>\n<p>You may be wondering what advantage this offers, given the backup is still written across the network \u2013 well, past an initial negotiation with nsrmmd on the storage node\/server for the file to write to, the client then handles the rest of the write itself, not bothering nsrmmd again. In other words \u2013 so long as the performance of the underlying filesystem can scale, the number of streams you can write to an AFTD can expand beyond the maximum number of nsrmmd processes an AFTD or storage node can handle.<\/p>\n<p>At this point, the &#8220;Device Access Information&#8221; is used as a multi-line field, with each subsequent line representing an alternate path the AFTD is visible at:<\/p>\n<p><a href=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-multimount.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-3869\" title=\"AFTD multimount\" src=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-multimount.png\" alt=\"AFTD multimount\" width=\"508\" height=\"368\" srcset=\"https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-multimount.png 508w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-multimount-300x217.png 300w, https:\/\/nsrd.info\/blog\/wp-content\/uploads\/2012\/07\/AFTD-multimount-414x300.png 414w\" sizes=\"auto, (max-width: 508px) 100vw, 508px\" \/><\/a><\/p>\n<p>So, the backup process will work such that if the pool allows the specified AFTD to be used for backup,\u00a0<em>and<\/em> the AFTD volume is visible to a client with &#8220;Client direct&#8221; setting enabled (a new option in the Client resource), on one of the paths specified,\u00a0<em>then<\/em> the client will negotiate access to the device through a device-owner nsrmmd process, and go on to write the backup itself.<\/p>\n<p>Note that this isn&#8217;t designed for sharing AFTDs between storage nodes \u2013 just between a server\/storage node and clients.<\/p>\n<p>Also, in case you&#8217;re skeptical, if your OS supports gathering statistics from the network-mount mechanism in use, you can fairly readily see whether NetWorker is honouring the direct access option. For instance, in the above configuration, I had a client called &#8216;nimrod&#8217; mounting the disk backup unit via NFS from the backup server; before the backup started on a new, fresh mount, nfsstat showed no activity. After the backup, nfsstat yielded the following:<\/p>\n<pre>[root@nimrod ~]# <strong>nfsstat<\/strong>\nClient rpc stats:\ncalls      retrans    authrefrsh\n834        0          0<\/pre>\n<pre>Client nfs v3:\nnull         getattr       setattr\u00a0 \u00a0 \u00a0\u00a0lookup\u00a0 \u00a0 \u00a0 \u00a0access\u00a0 \u00a0 \u00a0 \u00a0readlink \n0         0% 7          0% 3         0% 4         0% 9         1% 0         0% \nread         write         create       mkdir        symlink      mknod \n0         0% 790       94% 1         0% 0         0% 0         0% 0         0% \nremove       rmdir         rename       link         readdir      readdirplus \n1         0% 0          0% 0         0% 0         0% 0         0% 0         0% \nfsstat       fsinfo        pathconf     commit \n10        1% 2          0% 0         0% 6         0%<\/pre>\n<p>NetWorker also reports in the savegroup completion report that a client successfully negotiated direct file access (DFA) for a backup, too:<\/p>\n<pre>* nimrod:All savefs nimrod: succeeded.\n* nimrod:\/boot 86705:save: Successfully established DFA session with adv_file device for save-set ID '1694225141' (nimrod:\/boot).\nV nimrod: \/boot                    level=5,          0 KB 00:00:01      0 files\n* nimrod:\/boot completed savetime=1341899894\n* nimrod:\/ 86705:save: Successfully established DFA session with adv_file device for save-set ID '1677447928' (nimrod:\/).\nV nimrod: \/                        level=5,         25 MB 00:01:16    327 files\n* nimrod:\/ completed savetime=1341899897\n* nimrod:index 86705:save: Successfully established DFA session with adv_file device for save-set ID '1660670793' (nox:index:65768fd6-00000004-4fdfcfef-4fdfd013-00041a00-3d2a4f4b).\n nox: index:nimrod                 level=5,        397 KB 00:00:00     25 files\n* nimrod:index completed savetime=1341903689<\/pre>\n<p>Finally, logging is done in the server daemon.raw to also indicate that a DFA save has been negotiated:<\/p>\n<pre>91787 07\/10\/2012 05:00:05 PM \u00a01 5 0 1626601168 4832 0 nox nsrmmd NSR notice Save-set ID '1694225141' \n(nimrod:\/boot) is using direct file save with adv_file device 'AFTD1'.<\/pre>\n<p>The net result of all these architectural changes to AFTDs is a significant improvement over v7.x AFTD handling, performance and efficiency.<\/p>\n<p>(As noted previously though, this doesn&#8217;t apply\u00a0<em>just<\/em> to AFTDs, for what it&#8217;s worth \u2013 that client direct functionality also applies to Data Domain Boost devices, which allows a Data Domain system to integrate even more closely into a NetWorker environment. Scaling, scaling, scaling: it&#8217;s all about scaling.)<\/p>\n<p>In order to get the full benefit, I believe sites currently using AFTDs will probably go through the most pain; those who have been using VTLs may have a cost involved in the transition, but they&#8217;ll be able to transition to an optimal architecture almost immediately. However, sites with multiple smaller AFTDs won&#8217;t see the full benefits of the new architecture until they redesign their backup to disk environment, increasing the size of backup volumes. That being said, the change pain will be worth it for the enhancements received.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>As mentioned in my main NetWorker 8 introduction article, one of the biggest architectural enhancements in NetWorker v8 is a&hellip;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[3,16],"tags":[104,175,226,243,656,668,677,1252,932,1066],"class_list":["post-3859","post","type-post","status-publish","format-standard","hentry","category-architecture","category-networker","tag-aftd","tag-boost","tag-clone","tag-concurrency","tag-nsrclone","tag-nsrmmd","tag-nsrstage","tag-recovery","tag-stage","tag-v8"],"aioseo_notices":[],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/pKpIN-10f","jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"_links":{"self":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts\/3859","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/comments?post=3859"}],"version-history":[{"count":0,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts\/3859\/revisions"}],"wp:attachment":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/media?parent=3859"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/categories?post=3859"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/tags?post=3859"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}