<!-- 
RSS generated by JIRA (9.4.14#940014-sha1:734e6822bbf0d45eff9af51f82432957f73aa32c) at Sat Feb 10 02:43:47 UTC 2024

It is possible to restrict the fields that are returned in this document by specifying the 'field' parameter in your request.
For example, to request only the issue key and summary append 'field=key&field=summary' to the URL of your request.
-->
<rss version="0.92" >
<channel>
    <title>Whamcloud Community JIRA</title>
    <link>https://jira.whamcloud.com</link>
    <description>This file is an XML representation of an issue</description>
    <language>en-us</language>    <build-info>
        <version>9.4.14</version>
        <build-number>940014</build-number>
        <build-date>05-12-2023</build-date>
    </build-info>


<item>
            <title>[LU-11428] Writeback on close for DoM</title>
                <link>https://jira.whamcloud.com/browse/LU-11428</link>
                <project id="10000" key="LU">Lustre</project>
                    <description>&lt;p&gt;Writeback on close is to piggyback the dirty data for DoM files in the close RPC if the data could fit into the inline buffer. This way it should be able to improve write on small files significantly.&lt;/p&gt;

&lt;p&gt;I have had this idea before and I have seen this problem in my recent test. The writeback to small files are really slow and no matter how large the number I set it to max_rpcs_in_flight of mdc, it could simply max out. Small RPCs are expensive. An alternative solution would be to have compound RPC to merge those small RPCs but it would introduce more issues. The easier solution is to have writeback on close.&lt;/p&gt;</description>
                <environment></environment>
        <key id="53422">LU-11428</key>
            <summary>Writeback on close for DoM</summary>
                <type id="7" iconUrl="https://jira.whamcloud.com/images/icons/issuetypes/task_agile.png">Technical task</type>
                            <parent id="49050">LU-10176</parent>
                                    <priority id="4" iconUrl="https://jira.whamcloud.com/images/icons/priorities/minor.svg">Minor</priority>
                        <status id="1" iconUrl="https://jira.whamcloud.com/images/icons/statuses/open.png" description="The issue is open and ready for the assignee to start work on it.">Open</status>
                    <statusCategory id="2" key="new" colorName="default"/>
                                    <resolution id="-1">Unresolved</resolution>
                                        <assignee username="tappro">Mikhail Pershin</assignee>
                                    <reporter username="Jinshan">Jinshan Xiong</reporter>
                        <labels>
                            <label>DoM2</label>
                    </labels>
                <created>Tue, 25 Sep 2018 21:42:34 +0000</created>
                <updated>Tue, 20 Oct 2020 14:38:20 +0000</updated>
                                                                                <due></due>
                            <votes>0</votes>
                                    <watches>9</watches>
                                                                            <comments>
                            <comment id="234050" author="tappro" created="Thu, 27 Sep 2018 07:04:04 +0000"  >&lt;p&gt;Yes, this optimisation is in my list too though I wasn&apos;t thinking about details so far. The solution with inline data buffer on close looks easier than read-on-open because we can allocate buffer on needed size up to reasonable maximum. The problem can be the buffer preparation on a client probably.  Do you have an idea how to combine that with CLIO?&lt;/p&gt;</comment>
                            <comment id="234285" author="jgmitter" created="Wed, 3 Oct 2018 16:01:06 +0000"  >&lt;p&gt;Jinshan,&lt;/p&gt;

&lt;p&gt;Any thoughts on the above?&lt;/p&gt;

&lt;p&gt;Thanks.&lt;/p&gt;

&lt;p&gt;Joe&lt;/p&gt;</comment>
                            <comment id="234384" author="jinshan" created="Thu, 4 Oct 2018 19:33:54 +0000"  >&lt;p&gt;That&apos;s pretty much what OSC is currently doing right now. In the close handling on the MDC layer, it will call routines like cl_page_make_ready() to clear page Dirty bit and put page into writeback state. After close RPC is complete, it will clear page writeback bit.&lt;/p&gt;

&lt;p&gt;I didn&apos;t realize there is anything special for this, but I&apos;m pretty sure there will be some issue when this is implemented. We can discuss further that time then.&lt;/p&gt;</comment>
                            <comment id="242397" author="pfarrell" created="Wed, 20 Feb 2019 23:49:57 +0000"  >&lt;p&gt;So this would cut RPC counts by half and should reduce the RPC processing time for the write since it&apos;s inline rather than RDMA, but how big will this effect be relative to the writing itself?&#160; It sounds like in your testing, Jinshan, you were unable to keep the MDS busy because of rpc_in_flight limits.&lt;/p&gt;

&lt;p&gt;It seems like we should do this, but also raise the RPC in flight limit, unless the MDS CPU/disk was fully busy (which it sounds like it wasn&apos;t).&#160; And it sounds like raising the RPC in flight limit for the MDS might be a cheap win here.&lt;/p&gt;</comment>
                    </comments>
                <issuelinks>
                            <issuelinktype id="10011">
                    <name>Related</name>
                                            <outwardlinks description="is related to ">
                                        <issuelink>
            <issuekey id="55709">LU-12325</issuekey>
        </issuelink>
                            </outwardlinks>
                                                        </issuelinktype>
                    </issuelinks>
                <attachments>
                    </attachments>
                <subtasks>
                    </subtasks>
                <customfields>
                                                                                                                                                                <customfield id="customfield_10890" key="com.atlassian.jira.plugins.jira-development-integration-plugin:devsummary">
                        <customfieldname>Development</customfieldname>
                        <customfieldvalues>
                            
                        </customfieldvalues>
                    </customfield>
                                                                                                                                                                                                                                                                                                                                                        <customfield id="customfield_10390" key="com.pyxis.greenhopper.jira:gh-lexo-rank">
                        <customfieldname>Rank</customfieldname>
                        <customfieldvalues>
                            <customfieldvalue>1|i0033z:</customfieldvalue>

                        </customfieldvalues>
                    </customfield>
                                                                <customfield id="customfield_10090" key="com.pyxis.greenhopper.jira:gh-global-rank">
                        <customfieldname>Rank (Obsolete)</customfieldname>
                        <customfieldvalues>
                            <customfieldvalue>9223372036854775807</customfieldvalue>
                        </customfieldvalues>
                    </customfield>
                                                                                                                                                                                                                                                                                                                                                                                                                </customfields>
    </item>
</channel>
</rss>