Hi guys,

Thanks for more details Zhijiang.
It also looks to me that mapped memory size is mostly driven by OS limits
and bit-ness of JVM (32/64).

Thinking more about the 'Metrics' tab layout, couple of more things have
come into my mind.

# 'Metrics' tab -> 'Memory': 'Metrics' and 'Configuration' tabs

It contains only memory specific things and the design suggests not only
metrics but configuration as well.
Moreover, there are other metrics on top which are not in the metrics tab.
Therefore, I would name it 'Memory' and then add sub-tabs: e.g. 'Metrics'
and 'Configuration' tab.
Alternatively, one could consider splitting 'Metrics' into 'Metrics' and
'Configuration' tabs.

# Metrics (a bit different structure)

I would put memory metrics into 4 groups:
- JVM Memory
- Managed
- Network
- Garbage collection

Alternatively, one could consider:
- Managed by JVM (same as JVM Memory)
- Managed by Flink (Managed Segments and Network buffers)
- Garbage collection

## Total memory (remove from metrics)

As mentioned in the discussions before, it is hard to measure the total
memory usage.
Therefore, I would put into the configuration tab, see below.

## JVM Memory

Here we can have Heap, Non-Heap, Direct and mapped because they are all
managed by JVM.
Heap and direct can stay as they are.

### Non-Heap (could stay for now)

I think it is ok to keep Non-Heap for now because we had it also before.
This metric does not correlate explicitly with FLIP-49 but it is exposed by
JVM.
Once, we find better things to show (related only to JVM, e.g. Metaspace
etc), we can reconsider this as a follow-up.

### Mapped (looks still valuable)

As I understand at the moment, this can have a value for users to monitor
spilling of batch partitions.

### Metaspace (new, sub-component of Non-Heap, follow-up)

We have never had anything for the Metaspace. The recent experience shows
that it can be useful.
I would put it on road map as a follow-up though, because it also needs
some research and preparation on server side [1].

# Configuration (see Flink user docs picture)

We already have a picture in the docs representing memory components in
Flink [2].
The layout in this picture can be also used in this FLIP to depict the
actual configuration.
This would be more clear for users to see the same as we have in docs.

The configuration can also depict size of the total process and total Flink
memory according to docs.

As mentioned above, I also suggest to put it into a separate tab.

Best,
Andrey

[1]
https://kb.novaordis.com/index.php/Memory_Monitoring_and_Management_Platform_MBeans#Metaspace
[2]
https://ci.apache.org/projects/flink/flink-docs-release-1.10/ops/memory/mem_detail.html#overview


On Wed, Apr 1, 2020 at 8:03 PM Zhijiang <wangzhijiang...@aliyun.com.invalid>
wrote:

> Thanks for the FLIP, Yadong. In general I think this work is valuable for
> users to better understand the Flink's memory usages in different
> dimensions.
>
> Sorry for not going through every detailed discussions below, and I try to
> do that later if possible. Firstly I try to answer some Andrey's concerns
> with mmap.
>
> > - I do not know how the mapped memory works. Is it meant for the new
> spilled partitions? If the mapped memory also pulls from the direct
> > memory limit then this is something we do not account in our network
> buffers as I understand. In this case, this metric may be useful for tuning
> to understand
> > how much the mapped memory uses from the direct memory limit to set e.g.
> framework off-heap limit correctly and avoid direct OOM.
> > It could be something to discuss with Zhijiang. e.g. is the direct
> memory used there to buffer fetched regions of partition files or what for?
>
> Yes, the mapped memory is used in bounded blocking partition for batch
> jobs now, but not the default mode.
>
>  AIK it is not related and limited to the setting of `MaxDirectMemory`, so
> we do not need to worry about the current direct memory setting and the
> potential OOM issue.
> It is up to the address space to determine the mapped file size, and in 64
> bit system we can regard the limitless size in theory.
>
> Regarding the size of mapped buffer pool from MXBean, it only indicates
> how much file size were already mapped before, even it is unchanged to not
> reflect the real
> physical memory use. E.g. when the file was mapped 100GB region at the
> beginning, the mapped buffer pool from MXBean would be 100GB. But how many
> physical
> memories are really consumed is up to the specific read or write
> operations in practice, and also controlled by the operator system. E.g
> some unused regions might be
> exchanged into SWAP virtual memory when physical memory is limited.
>
> From this point, I guess it is no meaningful to show the size of mapped
> buffer pool for users who may be more concerned with how many physical
> memories are really
> used.
>
> Best,
> Zhijiang
>
>
> ------------------------------------------------------------------
> From:Andrey Zagrebin <azagre...@apache.org>
> Send Time:2020 Mar. 30 (Mon.) 22:56
> To:dev <dev@flink.apache.org>
> Subject:Re: [VOTE] FLIP-102: Add More Metrics to TaskManager
>
> Hi All,
>
> Thanks for this FLIP, Yadong. This is a very good improvement to the
> Flink's UI.
> It looks like there are still couple of things to resolve before the final
> vote.
>
> - I also find the non-heap title in configuration confusing because there
> are also other non-heap types of memory. The "off-heap" concept is quite
> broad.
> What about "JVM specific" meaning that it is not coming directly from
> Flink?
> or we could remove the "Non-heap" box at all and show directly JVM
> Metaspace and Overhead as separate boxes,
> this would also fit if we decide to keep the Metaspace metric.
>
> - Total Process Memory Used: I agree with Xintong, it is hard to say what
> is used there.
> Then the size of "Total Process Memory" basically becomes part of
> configuration.
>
> - Non-Heap Used/Max/.. Not sure what committed means here. I also think we
> should either exclude it or display what is known for sure.
> In general, the metaspace usage would be nice to have but it should be then
> exactly metaspace usage without any thing else.
>
> - I do not know how the mapped memory works. Is it meant for the new
> spilled partitions? If the mapped memory also pulls from the direct
> memory limit
> then this is something we do not account in our network buffers as I
> understand. In this case, this metric may be useful for tuning to
> understand
> how much the mapped memory uses from the direct memory limit to set e.g.
> framework off-heap limit correctly and avoid direct OOM.
> It could be something to discuss with Zhijiang. e.g. is the direct
> memory used there to buffer fetched regions of partition files or what for?
>
> - Not sure, we need an extra wrapping box "other" for the managed memory
> atm. I could be just "Managed" or "Managed by Flink".
>
> Best,
> Andrey
>
> On Fri, Mar 27, 2020 at 6:13 AM Xintong Song <tonysong...@gmail.com>
> wrote:
>
> > Sorry for the late response.
> >
> > I have shared my suggestions with Yadong & Lining offline. I think it
> would
> > be better to also post them here, for the public record.
> >
> >    - I'm not sure about displaying Total Process Memory Used. Currently,
> we
> >    do not have a good way to monitor all memory footprints of the
> process.
> >    Metrics for some native memory usages (e.g., thread stack) are absent.
> >    Displaying a partial used memory size could be confusing for users.
> >    - I would suggest merge the current Mapped Memory metrics into Direct
> >    Memory. Actually, the metrics are retrieved from MXBeans for direct
> > buffer
> >    pool and mapped buffer pool. Both of the two pools are accounted for
> in
> >    -XX:MaxDirectMemorySize. There's no Flink configuration that can
> modify
> > the
> >    individual pool sizes. Therefore, I think displaying the total Direct
> >    Memory would be good enough. Moreover, in most use cases the size of
> > mapped
> >    buffer pool is zero and users do not need to understand what is Mapped
> >    Memory. For expert users who do need the separated metrics for
> > individual
> >    pools, they can subscribe the metrics on their own.
> >    - I would suggest to not display Non-Heap Memory. Despite the name,
> the
> >    metrics (also retrieved from MXBeans) actually accounts for metaspace,
> > code
> >    cache, and compressed class space. It does not account for all JVM
> > native
> >    memory overheads, e.g., thread stack. That means the metrics of
> Non-Heap
> >    Memory do not well correspond to any of the FLIP-49 memory components.
> > They
> >    account for Flink's JVM Metaspace and part of JVM Overhead. I think
> this
> >    brings more confusion then help to users, especially primary users.
> >
> >
> > Thank you~
> >
> > Xintong Song
> >
> >
> >
> > On Thu, Mar 26, 2020 at 6:34 PM Till Rohrmann <trohrm...@apache.org>
> > wrote:
> >
> > > Thanks for updating the FLIP Yadong.
> > >
> > > What is the difference between managedMemory and managedMemoryTotal
> > > and networkMemory and networkMemoryTotal in the REST response? If they
> > are
> > > duplicates, then we might be able to remove one.
> > >
> > > Apart from that, the proposal looks good to me.
> > >
> > > Pulling also Andrey in to hear his opinion about the representation of
> > the
> > > memory components.
> > >
> > > Cheers,
> > > Till
> > >
> > > On Thu, Mar 19, 2020 at 11:37 AM Yadong Xie <vthink...@gmail.com>
> wrote:
> > >
> > >> Hi all
> > >>
> > >> I have updated the design of the metric page and FLIP doc, please let
> me
> > >> know what you think about it
> > >>
> > >> FLIP-102:
> > >>
> > >>
> >
> https://cwiki.apache.org/confluence/display/FLINK/FLIP-102%3A+Add+More+Metrics+to+TaskManager
> > >> POC web:
> > >>
> > >>
> >
> http://101.132.122.69:8081/web/#/task-manager/8e1f1beada3859ee8e46d0960bb1da18/metrics
> > >>
> > >> Till Rohrmann <trohrm...@apache.org> 于2020年2月27日周四 下午10:27写道:
> > >>
> > >> > Thinking a bit more about the problem whether to report the
> aggregated
> > >> > memory statistics or the individual slot statistics, I think
> reporting
> > >> it
> > >> > on a per slot basis won't work nicely together with FLIP-56 (dynamic
> > >> slot
> > >> > allocation). The problem is that with FLIP-56, we will no longer
> have
> > >> > dedicated slots. The number of slots might change over the lifetime
> > of a
> > >> > TaskExecutor. Hence, it won't be easy to generate a metric path for
> > >> every
> > >> > slot which are furthermore also ephemeral. So maybe, the more
> general
> > >> and
> > >> > easier solution would be to report the overall memory usage of a
> > >> > TaskExecutor even though it means to do some aggregation on the
> > >> > TaskExecutor.
> > >> >
> > >> > Concerning the JVM limit: Isn't it mainly the code cache? If we
> > display
> > >> > this value, then we should explain what exactly it means. I fear
> that
> > >> most
> > >> > users won't understand what JVM limit actually means.
> > >> >
> > >> > Cheers,
> > >> > Till
> > >> >
> > >> > On Wed, Feb 26, 2020 at 11:15 AM Yadong Xie <vthink...@gmail.com>
> > >> wrote:
> > >> >
> > >> > > Hi Till
> > >> > >
> > >> > > Thanks a lot for your response
> > >> > >
> > >> > > > 2. I'm not entirely sure whether I would split the memory ...
> > >> > >
> > >> > > Split the memory display comes from the 'ancient' design of the
> web,
> > >> it
> > >> > is
> > >> > > ok for me to change it following
> > total/heap/managed/network/direct/jvm
> > >> > > overhead/mapped sequence
> > >> > >
> > >> > > > 3. Displaying the memory configurations...
> > >> > >
> > >> > > I agree with you that it is not a very nice way, but the
> > hierarchical
> > >> > > relationship of configurations is too complex and hard to display
> in
> > >> the
> > >> > > other ways (I have tried)
> > >> > >
> > >> > > if anyone has a better idea, please feels no hesitates to help me
> > >> > >
> > >> > >
> > >> > > > 4. What does JVM limit mean in Non-heap.JVM-Overhead?
> > >> > >
> > >> > > JVM limit is "non-heap max metric minus metaspace configuration"
> as
> > >> > > @Xintong
> > >> > > Song <tonysong...@gmail.com> replyed in this mail thread
> > >> > >
> > >> > >
> > >> > > Till Rohrmann <trohrm...@apache.org> 于2020年2月25日周二 下午6:58写道:
> > >> > >
> > >> > > > Thanks for creating this FLIP Yadong. I think your proposal
> makes
> > it
> > >> > much
> > >> > > > easier for the user to understand what's happening on Flink
> > >> > > TaskManager's.
> > >> > > >
> > >> > > > I have some comments:
> > >> > > >
> > >> > > > 1. Some of the newly introduced metrics involve computations on
> > the
> > >> > > > TaskManager. I would like to avoid additional computations
> > >> introduced
> > >> > by
> > >> > > > metrics as much as possible because metrics should not affect
> the
> > >> > system.
> > >> > > > In particular, total memory sizes which are configured should
> not
> > be
> > >> > > > derived computationally (getManagedMemoryTotal,
> > getTotalMemorySize).
> > >> > For
> > >> > > > the currently available memory sizes (e.g.
> getManagedMemoryUsed),
> > >> one
> > >> > > could
> > >> > > > think about reporting them on a per slot basis and to do the
> > >> > aggregation
> > >> > > on
> > >> > > > the client side. Of course, this would increase the size of the
> > >> > response
> > >> > > > payload.
> > >> > > >
> > >> > > > 2. I'm not entirely sure whether I would split the memory
> display
> > >> into
> > >> > > JVM
> > >> > > > memory and non JVM memory as you've done it int the POC. From a
> > >> user's
> > >> > > > perspective, one could start displaying the total process
> memory.
> > >> The
> > >> > > next
> > >> > > > three most important metrics are the heap, managed memory and
> > >> network
> > >> > > > buffer usage, I guess. If one is interested in more details, one
> > >> could
> > >> > > then
> > >> > > > display the remaining direct memory usage, the JVM overhead (I'm
> > not
> > >> > sure
> > >> > > > whether I would call this non-heap though) and the mapped
> memory.
> > >> > > >
> > >> > > > 3. Displaying the memory configurations in three nested boxes
> does
> > >> not
> > >> > > look
> > >> > > > so nice to me. I'm not sure how else one could display it,
> though.
> > >> > > >
> > >> > > > 4. What does JVM limit mean in Non-heap.JVM-Overhead?
> > >> > > >
> > >> > > > Cheers,
> > >> > > > Till
> > >> > > >
> > >> > > > On Tue, Feb 25, 2020 at 8:19 AM Yadong Xie <vthink...@gmail.com
> >
> > >> > wrote:
> > >> > > >
> > >> > > > > Hi Xintong
> > >> > > > > thanks for your advice, the POC web and the FLIP doc was
> updated
> > >> now
> > >> > > > > here is the new link:
> > >> > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> >
> http://101.132.122.69:8081/web/#/task-manager/7e7cf0293645c8537caab915c829aa73/metrics
> > >> > > > >
> > >> > > > >
> > >> > > > > Xintong Song <tonysong...@gmail.com> 于2020年2月21日周五 下午12:00写道:
> > >> > > > >
> > >> > > > > > >
> > >> > > > > > > 1. Should the managed memory be part of direct memory?
> > >> > > > > > >
> > >> > > > > > The answer is no. Managed memory is currently allocated by
> > >> > accessing
> > >> > > to
> > >> > > > > > private field of Unsafe. It is not accounted for in JVM's
> > direct
> > >> > > memory
> > >> > > > > > limit and corresponding metrics. To that end, it is
> equivalent
> > >> to
> > >> > > > > > native memory.
> > >> > > > > >
> > >> > > > > >
> > >> > > > > > > 2. Should the shuffle memory also be part of the managed
> > >> memory?
> > >> > > > > >
> > >> > > > > > I don't think so. Shuffle (Network) memory is allocated with
> > >> direct
> > >> > > > > > buffers, and accounted for in JVM's direct memory limit and
> > >> > > > corresponding
> > >> > > > > > metrics. Moreover, the FLIP-49 memory model expose network
> > >> memory
> > >> > and
> > >> > > > > > managed memory as two independent components of the overall
> > >> memory
> > >> > > > > > footprint.
> > >> > > > > >
> > >> > > > > >
> > >> > > > > > Thank you~
> > >> > > > > >
> > >> > > > > > Xintong Song
> > >> > > > > >
> > >> > > > > >
> > >> > > > > >
> > >> > > > > > On Fri, Feb 21, 2020 at 11:45 AM Kurt Young <
> ykt...@gmail.com
> > >
> > >> > > wrote:
> > >> > > > > >
> > >> > > > > > > Some questions related to "managed memory":
> > >> > > > > > >
> > >> > > > > > > 1. Should the managed memory be part of direct memory?
> > >> > > > > > > 2. Should the shuffle memory also be part of the managed
> > >> memory?
> > >> > > > > > >
> > >> > > > > > > Best,
> > >> > > > > > > Kurt
> > >> > > > > > >
> > >> > > > > > >
> > >> > > > > > > On Fri, Feb 21, 2020 at 10:41 AM Xintong Song <
> > >> > > tonysong...@gmail.com
> > >> > > > >
> > >> > > > > > > wrote:
> > >> > > > > > >
> > >> > > > > > > > Thanks for driving this FLIP, Yadong.
> > >> > > > > > > >
> > >> > > > > > > > +1 (non-binding) for the FLIP in general. I think this
> > >> really
> > >> > > helps
> > >> > > > > our
> > >> > > > > > > > users to understand and use the new FLIP-49 memory
> > >> > configuration.
> > >> > > > > > > >
> > >> > > > > > > > I have a few minor comments.
> > >> > > > > > > > - There's a frame "Other" in the frame "Non-Heap",
> besides
> > >> "JVM
> > >> > > > > > Overhead"
> > >> > > > > > > > and "JVM Metaspace". IIUC, the purpose of this is to
> > explain
> > >> > the
> > >> > > > > > > > mismatching between the metric "non-heap maximum" and
> the
> > >> sum
> > >> > of
> > >> > > > the
> > >> > > > > > > > configurations "JVM metaspace" & "JVM Overhead".
> However,
> > >> from
> > >> > > the
> > >> > > > > > > > perspective of FLIP-49, JVM Overhead accounts for all
> the
> > >> JVM
> > >> > > > > non-heap
> > >> > > > > > > > memory usages except for metaspace. The metrics does not
> > >> match
> > >> > > the
> > >> > > > > > > > configuration because we did not set the a JVM parameter
> > for
> > >> > "max
> > >> > > > > > > non-heap
> > >> > > > > > > > memory" (actually I'm not sure whether it can be
> specified
> > >> in
> > >> > > java
> > >> > > > > 8).
> > >> > > > > > > The
> > >> > > > > > > > current UI might confuse people making them think there
> > are
> > >> > other
> > >> > > > > > > non-heap
> > >> > > > > > > > memory usages not accounted by the configurations.
> > >> Therefore, I
> > >> > > > would
> > >> > > > > > > > suggest to remove the "Other" frame, but add another
> frame
> > >> > inside
> > >> > > > > "JVM
> > >> > > > > > > > Overhead", besides "Configuration", with "JVM limit" as
> > the
> > >> > title
> > >> > > > and
> > >> > > > > > > > "non-heap max metric minus metaspace configuration" as
> the
> > >> > value
> > >> > > .
> > >> > > > > > > >
> > >> > > > > > > > - In the final release, we have changed "shuffle memory"
> > to
> > >> > > > "network
> > >> > > > > > > > memory" because the latter is easier to understand for
> > >> users. I
> > >> > > > think
> > >> > > > > > we
> > >> > > > > > > > should be updated it in this FLIP as well.
> > >> > > > > > > >
> > >> > > > > > > > - There's a typo "Directed" (should be "Direct") at the
> > >> direct
> > >> > > > memory
> > >> > > > > > > > metric.
> > >> > > > > > > >
> > >> > > > > > > > Thank you~
> > >> > > > > > > >
> > >> > > > > > > > Xintong Song
> > >> > > > > > > >
> > >> > > > > > > >
> > >> > > > > > > >
> > >> > > > > > > > On Thu, Feb 20, 2020 at 5:52 PM Yadong Xie <
> > >> > vthink...@gmail.com>
> > >> > > > > > wrote:
> > >> > > > > > > >
> > >> > > > > > > > > Hi all
> > >> > > > > > > > >
> > >> > > > > > > > > I want to start the vote for FLIP-102, which proposes
> to
> > >> add
> > >> > > more
> > >> > > > > > > metrics
> > >> > > > > > > > > to the task manager in web UI.
> > >> > > > > > > > >
> > >> > > > > > > > > To help everyone better understand the proposal, we
> > spent
> > >> > some
> > >> > > > > > efforts
> > >> > > > > > > on
> > >> > > > > > > > > making an online POC
> > >> > > > > > > > >
> > >> > > > > > > > > previous web:
> > >> > > > > > > > >
> > >> > > > > > > > >
> > >> > > > > > > >
> > >> > > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> >
> http://101.132.122.69:8081/#/task-manager/6df6c5f37b2bff125dbc3a7388128559/metrics
> > >> > > > > > > > > POC web:
> > >> > > > > > > > >
> > >> > > > > > > > >
> > >> > > > > > > >
> > >> > > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> >
> http://101.132.122.69:8081/web/#/task-manager/6df6c5f37b2bff125dbc3a7388128559/metrics
> > >> > > > > > > > >
> > >> > > > > > > > >
> > >> > > > > > > > > The vote will last for at least 72 hours, following
> the
> > >> > > consensus
> > >> > > > > > > voting
> > >> > > > > > > > > process.
> > >> > > > > > > > >
> > >> > > > > > > > > FLIP wiki:
> > >> > > > > > > > >
> > >> > > > > > > > >
> > >> > > > > > > >
> > >> > > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> >
> https://cwiki.apache.org/confluence/display/FLINK/FLIP-102%3A+Add+More+Metrics+to+TaskManager
> > >> > > > > > > > >
> > >> > > > > > > > > Discussion thread:
> > >> > > > > > > > >
> > >> > > > > > > > >
> > >> > > > > > > >
> > >> > > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> >
> http://apache-flink-mailing-list-archive.1008284.n3.nabble.com/DISCUSS-FLIP-75-Flink-Web-UI-Improvement-Proposal-td33540.html
> > >> > > > > > > > >
> > >> > > > > > > > > Thanks,
> > >> > > > > > > > >
> > >> > > > > > > > > Yadong
> > >> > > > > > > > >
> > >> > > > > > > >
> > >> > > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> > >
> >
>
>

Reply via email to